Webshr Core
A modern, modular framework for WordPress projects built with PHP 8.1+ and inspired by Laravel's architecture.
Overview
Webshr Core is a lightweight yet powerful framework designed specifically for WordPress development. It provides a clean, object-oriented approach to building WordPress themes and plugins with modern PHP features, dependency injection, and a modular architecture.
Features
- Modern PHP Architecture: Built with PHP 8.1+ using PSR-4 autoloading
- Modular System: Extensible module-based architecture for clean code organization
- Asset Management: Comprehensive asset handling with manifest support and bundling
- Dependency Injection: Service container for managing dependencies and bindings
- Encryption & Security: Built-in encryption utilities with multiple cipher support
- Configuration Management: Flexible configuration system with environment support
- Helper Functions: Rich set of utility functions for common WordPress tasks
- String Utilities: Comprehensive string manipulation helpers
- Filesystem Abstraction: Clean filesystem operations with proper error handling
Installation
composer require webshr/core
Quick Start
Basic Setup
<?php
// functions.php or your theme's bootstrap file
use Webshr\Core\Bootloader;
// Initialize the framework
$bootloader = Bootloader::get_instance();
$bootloader->boot();
Using the Application Container
use Webshr\Core\app;
// Get the application instance
$app = app();
// Resolve services from the container
$encryption = app('encryption');
$assets = app('assets');
Core Components
Application Container
The Application class serves as the main service container and communication hub:
use Webshr\Core\Application;
$app = new Application();
// Bind services
$app->instance('my-service', new MyService());
// Resolve services
$service = $app->make('my-service');
// Register singletons
$app->singleton('database', Database::class);
Module System
Create modular functionality using the module system:
use Webshr\Core\Module;
class MyModule extends Module
{
    public function register(): void
    {
        // Register WordPress hooks, services, etc.
        add_action('init', [$this, 'init']);
    }
    public function boot(): void
    {
        // Boot logic after registration
    }
    public function can_register(): bool
    {
        return true; // Conditional registration
    }
}
Asset Management
Handle assets with manifest support and bundling:
use Webshr\Core\asset;
use Webshr\Core\bundle;
// Get individual assets
$css = asset('styles/main.css');
$js = asset('scripts/app.js');
// Get asset bundles
$mainBundle = bundle('main');
// Enqueue CSS files
$mainBundle->css(function($handle, $src) {
    wp_enqueue_style($handle, $src);
});
// Enqueue JS files
$mainBundle->js(function($handle, $src, $deps) {
    wp_enqueue_script($handle, $src, $deps);
});
Encryption Utilities
Secure data with built-in encryption:
use Webshr\Core\encrypt;
use Webshr\Core\decrypt;
// Encrypt data
$encrypted = encrypt('sensitive data');
// Decrypt data
$decrypted = decrypt($encrypted);
// String-specific encryption (no serialization)
$encrypted = encrypt_string('plain text');
$decrypted = decrypt_string($encrypted);
String Utilities
Rich string manipulation helpers:
use Webshr\Core\Support\Str;
// String operations
Str::contains('Hello World', 'World'); // true
Str::starts_with('Hello World', 'Hello'); // true
Str::ends_with('Hello World', 'World'); // true
// String extraction
Str::before('user@example.com', '@'); // 'user'
Str::after('user@example.com', '@'); // 'example.com'
Str::between('Hello [World]', '[', ']'); // 'World'
// Pattern matching
Str::is('admin/*', 'admin/users'); // true
Configuration
Environment Configuration
The framework supports environment-based configuration:
// config/app.php
return [
    'paths' => [
        'base' => get_template_directory(),
        'config' => get_template_directory() . '/config',
        'resources' => get_template_directory() . '/resources',
        'storage' => get_template_directory() . '/storage',
    ],
    'modules' => [
        'theme' => ThemeModule::class,
        'assets' => AssetModule::class,
    ],
    'cipher' => 'aes-256-cbc',
    'key' => env('APP_KEY'),
];
Asset Configuration
Configure asset manifests and bundles:
// config/assets.php
return [
    'default' => 'main',
    'manifests' => [
        'main' => [
            'path' => get_template_directory() . '/dist',
            'url' => get_template_directory_uri() . '/dist',
            'assets' => get_template_directory() . '/dist/manifest.json',
            'bundles' => get_template_directory() . '/dist/bundles.json',
        ],
    ],
];
Helper Functions
The framework provides numerous helper functions:
// Application helpers
app(); // Get application instance
bootloader(); // Get bootloader instance
// Asset helpers
asset('path/to/file.css');
bundle('main');
meta('path/to/file.json');
// Module helpers
module('theme');
// Security helpers
encrypt($data);
decrypt($payload);
hash($data);
check($data, $hash);
// WordPress helpers
add_actions(['init', 'wp_enqueue_scripts'], $callback);
add_filters(['the_content', 'the_title'], $callback);
require_files('/path/to/directory');
Architecture
Directory Structure
src/
├── Application.php          # Main application container
├── Bootloader.php          # Application bootstrapper
├── Module.php              # Base module class
├── Assets/                 # Asset management system
│   ├── Manager.php         # Asset manager
│   ├── Manifest.php       # Asset manifest handler
│   ├── Bundle.php         # Asset bundle handler
│   └── Asset/             # Asset types
├── Modules/                # Module system
│   ├── Manager.php        # Module manager
│   └── Contracts/         # Module interfaces
├── Support/                # Support utilities
│   ├── Str.php            # String utilities
│   └── Traits/             # Reusable traits
├── Utility/                # Utility classes
│   ├── Encryption.php     # Encryption utilities
│   └── Hash.php           # Hashing utilities
├── Config/                 # Configuration management
├── Filesystem/             # Filesystem abstraction
└── Contracts/              # Framework interfaces
Key Design Patterns
- Service Container: Dependency injection and service resolution
- Module Pattern: Extensible, modular architecture
- Manager Pattern: Centralized management of resources
- Factory Pattern: Asset creation and instantiation
- Strategy Pattern: Pluggable encryption and hashing algorithms
Requirements
- PHP 8.1 or higher
- WordPress 5.0 or higher
- Composer for dependency management
Dependencies
- psr/container: PSR-11 container interface
- phpunit/phpunit: Testing framework (dev)
- squizlabs/php_codesniffer: Code quality (dev)
- wp-coding-standards/wpcs: WordPress coding standards (dev)
Development
Running Tests
composer test
Code Quality
composer lint
composer lint:fix
Coverage
composer coverage
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for new functionality
- Ensure all tests pass
- Submit a pull request
License
This project is licensed under the GPL-3.0-or-later License - see the LICENSE.md file for details.
Credits
- Author: Henrik Liebel (Webshore)
- Inspired by: Laravel Framework, Roots Acorn
- Website: webshore.eu
Support
For support and questions, please visit the project repository or contact mail@henrikliebel.com.