Technical Specifications

Framework Architecture

CloudOnex Business Suite is built on a custom framework optimized for business applications. Rather than using a single monolithic framework, it employs a modular approach incorporating best-in-class libraries for specific functionalities.

Core Components

1. Database Layer

  • Primary ORM: Laravel Eloquent
  • Usage Example:
use Illuminate\Database\Eloquent\Model;

class Customer extends Model
{
    protected $table = 'sys_customers';
    protected $fillable = ['name', 'email', 'phone'];
    
    public function invoices()
    {
        return $this->hasMany('Invoice');
    }
}

2. Caching System

  • Library: illuminate/cache
  • Features:
    • Multiple cache drivers support
    • Automatic cache invalidation
    • Tag-based caching
// Cache configuration
$cache = new Illuminate\Cache\Repository($store);
$cache->put('key', 'value', 60); // Store for 60 minutes

3. File System

  • Library: illuminate/filesystem
  • Capabilities:
    • File and directory manipulation
    • Cloud storage integration
    • Stream wrappers
use Illuminate\Filesystem\Filesystem;
$files = new Filesystem;
$files->put('path/to/file.txt', 'Content');

4. Console & Automation

  • Framework: symfony/console
  • Features:
    • Command-line interface
    • Scheduled tasks
    • Background jobs
use Symfony\Component\Console\Command\Command;

class DataSyncCommand extends Command
{
    protected function configure()
    {
        $this->setName('app:sync-data')
             ->setDescription('Synchronize data');
    }
}

5. Template Engine

  • Base: Smarty (Customized)
  • Extensions: Custom tags and modifiers
{* Template Example *}
{block name="content"}
    <div class="panel">
        <h3>{$title}</h3>
        {foreach $items as $item}
            <div>{$item.name}</div>
        {/foreach}
    </div>
{/block}

6. Routing System

  • Type: Custom Implementation
  • Features:
    • URL rewrite optional
    • Subfolder installation support
    • Automatic route resolution
// Example URL structure
// With URL rewrite: /customers/view/123
// Without URL rewrite: ?ng=customers/view/123

$action = route(2); // Gets the action segment
$id = route(3);     // Gets the ID segment

System Requirements

Server Requirements

  • PHP 8.2 or higher
  • Required PHP Extensions:
    • curl
    • json
    • mysqli
    • pdo
    • zip
    • mbstring
    • gd

Database Requirements

  • MySQL 5.7+ or MariaDB 10.2+
  • InnoDB storage engine
  • UTF8mb4 character set support

Dependencies

Core Libraries

{
    "illuminate/database": "*",
    "illuminate/cache": "*",
    "illuminate/filesystem": "*",
    "symfony/console": "*",
    "smarty/smarty": "*"
}

Additional Components

  • PDF Generation: mpdf/mpdf ^8.0
  • Email Handling: phpmailer/phpmailer ^6.6
  • Data Validation: rakit/validation ^1.4
  • Date/Time: nesbot/carbon ^2.62
  • HTTP Client: guzzlehttp/guzzle ^7.5

Application Structure

/
├── apps/           # Plugin directory
├── storage/        # File storage
├── system/
│   ├── autoload/  # Autoloader classes
│   ├── models/    # Core models
│   ├── controllers/
│   └── lib/       # Core libraries
├── ui/
│   └── theme/     # Theme files
└── vendor/        # Composer dependencies

Autoloading

PSR-0 Autoloading

"autoload": {
    "psr-0": {
        "": "system/autoload/"
    }
}

PSR-4 Autoloading

"autoload": {
    "psr-4": {
        "": "system/models/"
    }
}

Performance Optimization

Caching Configuration

// Production cache settings
define('CACHE_DRIVER', 'file'); // Options: file, redis, memcached
define('CACHE_PREFIX', 'clx_');

Database Optimization

// Query caching
DB::enableQueryLog();
DB::connection()->enableQueryLog();

Security Features

Input Validation


$validator = new Validator;
$validation = $validator->make($data, [
    'email' => 'required|email',
    'amount' => 'required|numeric'
]);

XSS Protection

  • HTMLPurifier integration
  • Automatic input sanitization
use HTMLPurifier;
$config = HTMLPurifier_Config::createDefault();
$purifier = new HTMLPurifier($config);
$clean_html = $purifier->purify($dirty_html);

Email Integration

use PHPMailer\PHPMailer\PHPMailer;

$mail = new PHPMailer(true);
$mail->isSMTP();
$mail->Host = SMTP_HOST;
$mail->SMTPAuth = true;

Development Tools

Debug Mode

// Enable development mode
define('APP_STAGE', 'Dev');

// Debug helper
function _debug($data) {
    if(APP_STAGE == 'Dev') {
        var_dump($data);
    }
}