gortonsd/marshal

A lightweight PHP framework with automatic controller discovery, route registration via docblock annotations, and intelligent route caching

Maintainers

Package info

github.com/gortonsd/marshal

Issues

pkg:composer/gortonsd/marshal

Fund package maintenance!

gortonsd

Statistics

Installs: 3

Dependents: 0

Suggesters: 0

Stars: 0

dev-main 2025-08-22 01:47 UTC

This package is auto-updated.

Last update: 2026-03-22 03:25:48 UTC


README

Marshal is a lightweight PHP framework designed to make building web applications simple and intuitive. With Marshal, you can focus on your application's logic while the framework handles routing, controller discovery, and more.

Key Features

  • Attribute-Based Routing: Define your routes using PHP attributes. Simply add a #[RouteAttribute(url: '/your-url')] attribute to your controller class and Marshal will automatically register the route.
  • Simple Controller Inheritance: Extend gortonsd\Marshal\Controller to create your own controllers. Marshal takes care of all the heavy lifting, so you only need to implement your HTTP methods (get(), post(), etc.).
  • Automatic Controller Discovery: Marshal scans your controllers folder and registers routes automatically, keeping your codebase clean and organized.
  • Ready for Expansion: The framework is designed to be extended, with plans for request/response helpers, middleware, and more.

Getting Started

  1. Install Marshal (coming soon via Composer)
  2. Create a Controller
use gortonsd\Marshal\RouteAttribute;
use gortonsd\Marshal\Controller;

#[RouteAttribute(url: '/example')]

class ExampleController extends Controller {
	public function get() {
		echo "Hello from ExampleController!";
	}
}

Note: Controllers can also specify optional name and middleware parameters in the RouteAttributes attribute for advanced routing and access control.

  1. Run Marshal
use gortonsd\Marshal\Router;

$controllersPath = __DIR__ . '/Controllers'; // Path to your controllers
$router = new Router($controllersPath); // Uses cache if available
// $router = new Router($controllersPath, true); // Force refresh and rebuild route cache
$router->run();

Route Cache Behavior

  • Marshal caches discovered routes in a JSON file for fast startup.
  • By default, the cache is used if available. To force a refresh (e.g., after adding new controllers), pass true as the second argument to the Router constructor.
  • Example: $router = new Router($controllersPath, true);
  • Cache will be built if it does not already exist

Philosophy

Marshal aims to provide a modern, minimal, and developer-friendly experience for PHP web development. By leveraging PHP attributes and convention over configuration, Marshal lets you build robust applications with less boilerplate.

Marshal: The simple way to marshal your web requests.