Core Boxx – Core Engine & Concepts

TABLE OF CONTENTS

 

FILES CONFIG NOTES

Files and config list for this module, and some notes (if any).

 

FILES LIST

  • lib/CORE-Go.php The “firestarter”. All your scripts only need to include this file to get Core Boxx started.
  • lib/CORE-Config.php System settings.
  • lib/LIB-Core.php The core engine itself.

 

CORE ENGINE CONCEPTS

TLDR – Core Boxx is a funky and super lazy engine.

 

PART 1) A QUICK TRACE OF WHAT HAPPENS

1A) OLD SCHOOL OBJECT

lib/LIB-Core.php
class CoreBoxx { ... }
 
// (G) CORE OBJECT + GLOBAL ERROR HANDLING
$_CORE = new CoreBoxx();

In CORE-Go.php, we require "LIB-Core.php" and $_CORE will magically appear. Here is the answer.

 

 

1B) EXTEND OBJECT

lib/LIB-Core.php
// (B2) LOAD MODULE
// $module : module to load
function load ($module) : void {
  if ($this->loaded($module)) { return; }
  $file = PATH_LIB . "LIB-$module.php";
  if (file_exists($file)) {
    require $file;
    $this->modules[$module] = new $module($this);
  } else { throw new Exception("$module module not found!"); }
}

The whole idea of “modular” is to extend the $_CORE object using $_CORE->load(). Let us walk through what happens when we load the database module using $_CORE->load("DB"):

  • require "LIB-DB.php";
  • $_CORE->modules["DB"] = new DB($_CORE);

Yes, that’s all. It’s just “normal OOP in a lazy manner”.

 

1C) LAZY REFERENCE

lib/LIB-Core.php
// (B3) "MAGIC LINK" TO MODULE
function __get ($name) {
  if (isset($this->modules[$name])) { return $this->modules[$name]; }
}

With the database module loaded, we can now access the database functions with $_CORE->modules["DB"]->FUNCTION(). But staying true to “as lazy as possible”, let’s shorten that to $_CORE->DB->FUNCTION() using the magic __get().

 

 

1D) MODULES LINKING

lib/LIB-Core.php
// (F) ALL MODULES SHOULD EXTEND THIS CORE CLASS
class Core {
  // (F1) LINK MODULE TO CORE
  public $Core;
  public $error;
  function __construct ($core) {
    $this->Core =& $core;
    $this->error =& $core->error;
  }
 
  // (F2) MAKE MODULES LINKING EASIER
  function __get ($name) {
    if (isset($this->Core->modules[$name])) { return $this->Core->modules[$name]; }
  }
}

Finally, notice that we pass in the core object when loading modules $_CORE->modules["DB"] = new DB($_CORE). To explain why this is essential for lazy people:

  • $_CORE->DB->Core =& $_CORE
  • $_CORE->DB->error =& $_CORE->error
  • The same old trick with magic __get(). In all the functions of $_CORE->DB, $this->MOD will refer to $_CORE->modules["MOD"].

In short, this will “link” all modules together using pointers. Unorthodox? Yes, but it’s not illegal.

 

PART 2) LAZY AUTO-CALL FUNCTIONS

YUCK.
// LET'S SAY WE SUBMIT A FORM
$_CORE->load("MyLib");
$result = $_CORE->MyLib->save(
  $_POST["name"], $_POST["email"], $_POST["tel"]
);

This is what “normal people” do to pass a submitted form to a library function. It works. But do this over a million times, and you will be sick of this “map parameters to function sh*t”.

 

YES!
$result = $_CORE->autoCall("MyLib", "save");

Study $_CORE->autoCall() if you want, but it pretty much does “EVIL EVAL” to map $_POST $_GET to the specified module/function. Unorthodox? So what? Would you rather do countless hours of “parameters mapping”?

 

 

PART 3) GLOBAL ERROR HANDLER

LIB-Core.php
// (G) CORE OBJECT + GLOBAL ERROR HANDLING
function _CORERR ($ex) { global $_CORE; $_CORE->ouch($ex); }
set_exception_handler("_CORERR");

One last bit to highlight:

  • All the errors will be handled by $_CORE->ouch().
  • When serving HTML pages, it will show something like a “blue screen of death”. Otherwise, it just outputs a JSON-encoded error message.
  • In CORE-Config.php, you may want to hide the error messages on your live server – Keep the error messages in a log file instead.

 

CORE LIBRARY REFERENCES

Now for the list of library functions, and a few short examples.

 

PROPERTIES

  • $modules – Array to “store” loaded modules.
  • $error – Last error message.
  • $page – Pagination data.
  • $mode – Current “operation mode”.
    • C Command line.
    • W Serving a webpage.
    • A Answering an API call.

 

 

MODULES

function load ($module)

Loads lib/LIB-$module.php, and extends it to $_CORE->modules[$module] = new $module();

  • $module – String, module to load.
$_CORE->load("Users");
function loaded ($module)

Checks if the specified $module is loaded.

  • $module – String, module to check.
if ($_CORE->loaded("Users")) { ... }

 

FUNCTION MAPPING

function autoCall ($module, $function, $mode)

Automatically map POST or GET variables to the specified module function, and run it.

  • $module – String, module to load.
  • $function – String, function to call.
  • $mode – String, POST or GET. Defaults to POST.
$users = $_CORE->autoCall("Users", "getAll");
function autoAPI ($actions, $mode)

Automatically map POST or GET variables to the specified module function, and respond after running it.

  • $actions – Array. The list of API actions and respective module/function handler.
  • $mode – String, POST or GET. Defaults to POST.
$_CORE->autoAPI([
  ["get" => ["Users", "get"]],
  ["save" => ["Users", "save"]],
  ["del" => ["Users", "del"]],
]);

 

SYSTEM

function respond ($status, $msg, $data, $more, $http, $exit)

Formats and outputs a standard JSON encoded string.

  • $status – Boolean, 1, 0, or invent your own set of status code.
  • $msg – String, system message.
  • $data – Data if any.
  • $more – Additional data, if any.
  • $http – Optional, HTTP response code.
  • $exit – Optional, stop processing after JSON string output. Defaults to true.
$_CORE->respond(0, "An error has occurred!", null, null, 500);
function ouch ($ex)

Nothing to see here. This one is used to handle errors globally.

 

OTHER CONVENIENCE

function random ($length)

Creates an alphanumeric string.

  • $length – Integer, number of characters. Defaults to 8.
$password = $_CORE->random(10);
function paginator ($entries, $now)

Calculates pagination.

  • $entries – Integer, the total number of entries.
  • $now – Integer, the current page number.
$entries = 1234; // DO YOUR OWN SELECT COUNT(*) FROM `TABLE`
$now = 4; // CURRENT PAGE
$_CORE->paginator($entries, $now);
/* $_CORE->page = [
  "entries" => TOTAL NUMBER OF ENTRIES
  "total" => TOTAL NUMBER OF PAGES
  "now" => CURRENT PAGE
  "x" => STARTING ENTRY
  "y" => ENDING ENTRY
  "lim" => "LIMIT X,Y" FOR SQL QUERIES
] */
function redirect ($page, $url)

HTTP redirect.

  • $page – Page or path.
  • $url – Defaults to HOST_BASE.
if (!isset($_SESSION["user"])) {
  $_CORE->redirect("login/");
}
function ucheck ($lvl, $redirect)

Requires the user module, user level access check.

  • $lvl – Required level to access.
    • true As long as signed in.
    • STRING Must be this specific level.
  • $redirect – String, redirect to this page if the user does not have sufficient rights. Optional.
// ONLY ADMINISTRATORS CAN ACCESS THIS PAGE OR API
$_CORE->ucheck("A");

 

CORE BOXX INSTALLER

Quick notes on how to reuse the installer for your own project.

 

INSTALLER FILES LIST

  • assets/tsparticles.confetti.bundle.min.js tsParticles Confetti library.
  • lib/CORE-Install.php This is the “install starter”.
  • lib/LIB-Install.php Installation process.
  • lib/CORE-Install-HTML.php The installation page.
  • lib/CORE-Install-JS.php The installation Javascript.

 

REPACKAGING YOUR PROJECT

  • Export your database, and place the sql file in the lib folder. Make sure there’s no sensitive data such as users and keys.
  • Edit CORE-Config.php, remove all your “sensitive” settings – Database, host, keys, etc…
  • Edit LIB-Install.php, go through phase A, and set your requirements.
  • Edit CORE-Install-HTML.php, change section C12. Add your links and “congratulations” messages.
  • Edit index.php, start the installer – require lib/CORE-Install.php.

That’s all.