- Event-driven architecture with lazy module loading - ModuleScanner, ModuleRegistry, LazyModuleListener for module discovery - 7 lifecycle events: Web, Admin, API, Client, Console, MCP, FrameworkBooted - AdminMenuProvider and ServiceDefinition contracts - Artisan commands: make:mod, make:website, make:plug - Module stubs for rapid scaffolding - Comprehensive test suite with Orchestra Testbench - GitHub Actions CI for PHP 8.2-8.4 / Laravel 11-12 - EUPL-1.2 license Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
36 lines
789 B
Text
36 lines
789 B
Text
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Website\{{ name }};
|
|
|
|
use Core\Events\WebRoutesRegistering;
|
|
use Illuminate\Support\ServiceProvider;
|
|
|
|
/**
|
|
* Website module for {{ name }}.
|
|
*
|
|
* Website modules are domain-scoped and typically serve
|
|
* marketing sites, landing pages, or standalone web properties.
|
|
*/
|
|
class Boot extends ServiceProvider
|
|
{
|
|
/**
|
|
* Events this website listens to.
|
|
*/
|
|
public static array $listens = [
|
|
WebRoutesRegistering::class => 'onWebRoutes',
|
|
];
|
|
|
|
/**
|
|
* Handle web routes registration.
|
|
*/
|
|
public function onWebRoutes(WebRoutesRegistering $event): void
|
|
{
|
|
$event->views('{{ slug }}', __DIR__.'/Views');
|
|
|
|
$event->routes(function () {
|
|
require __DIR__.'/Routes/web.php';
|
|
});
|
|
}
|
|
}
|