decodelabs/genesis

Universal bootstrapping framework

Installs: 18 776

Dependents: 8

Suggesters: 1

Security: 0

Stars: 2

Watchers: 2

Forks: 0

Open Issues: 0

Type:composer-plugin

pkg:composer/decodelabs/genesis

v0.14.7 2025-09-14 16:34 UTC

README

PHP from Packagist Latest Version Total Downloads GitHub Workflow Status PHPStan License

Universal bootstrapping framework for PHP applications

Genesis provides everything you need to bootstrap your application at runtime. Take the guesswork out of how best to structure the lowest level code in your framework and app.

Installation

This package requires PHP 8.4 or higher.

Install via Composer:

composer require decodelabs/genesis

Usage

Hub

Genesis requires consumers of the library to implement a number of interfaces to represent important parts of the bootstrap process. With these classes in place, it is then able to provide a unified, dependable bootstrap process for all environments.

Most important is the Hub interface:

namespace DecodeLabs\Genesis;

use DecodeLabs\Genesis\Environment\Config as EnvConfig;
use DecodeLabs\Genesis\Build\Manifest as BuildManifest;
use DecodeLabs\Kingdom;

interface Hub
{
    public ?BuildManifest $buildManifest { get; }

    public function initializeLoaders(): void;
    public function loadBuild(): Build;
    public function loadEnvironmentConfig(): EnvConfig;
    public function initializePlatform(): void;
    public function loadKingdom(): Kingdom;
}

Bootstrapping

Genesis now runs as a composer plugin, automatically generating an entry point for your application when composer updates.

You just need to add make sure you have set your composer type ('project' for a standalone app, 'library' for a library) and your Hub class to the genesis.hub extra key in your composer.json file:

{
    "extra": {
        "genesis": {
            "hub": "My\\Genesis\\Hub"
        }
    }
}

You can then point your HTTP server to rewite to vendor/genesis.php as your entry point. Genesis takes care of the rest.

Compiled builds

Genesis supports an advanced build compilation process which can be used for isolating active runtime code from the source of your application. This is especially useful for legacy frameworks that can't easily be deployed using a third party automated deployment system.

Compiled builds are a complex topic due to the necessity of locating the correct build folder before loading any other code and needing to seamlessly deploy updates without unwittingly mixing different versions of libraries during execution.

Full details of how to work with compiled builds can be found here.

Licensing

Genesis is licensed under the MIT License. See LICENSE for the full license text.