glugox / module
Module abstractions that all modules use
Installs: 25
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 1
pkg:composer/glugox/module
Requires
- php: >=8.2
Requires (Dev)
- driftingly/rector-laravel: ^2.0.7
- fakerphp/faker: ^1.24.1
- larastan/larastan: ^3.7.2
- laravel/boost: ^1.3.0
- laravel/pail: ^1.2.3
- laravel/pint: ^1.25.1
- mockery/mockery: ^1.6.12
- nunomaduro/collision: ^8.8.2
- orchestra/testbench: ^10.6.0
- pestphp/pest: ^4.1
- pestphp/pest-plugin-browser: ^4.1.1
- pestphp/pest-plugin-laravel: ^4.0.0
- pestphp/pest-plugin-type-coverage: ^4.0.2
- rector/rector: ^2.2.2
This package is auto-updated.
Last update: 2025-10-31 10:39:37 UTC
README
Introduction
The glugox/module package defines the foundation for modular development in Laravel. It introduces the common abstractions, contracts, and base classes that every module must use. This ensures consistency across all modules and makes it possible for tools like glugox/orchestrator and glugox/module-generator to integrate seamlessly.
Key Concepts
1. Module Abstraction
- A module is a self-contained package that adds functionality to a Laravel app.
- Every module must implement the
ModuleContractor extend the abstractModulebase class. - A module contains its own routes, migrations, views, assets, and service providers.
2. Module Manifest
- The manifest describes the metadata of a module.
- It includes:
id,name,namespace,description,version, andcapabilities. - It allows orchestrators to discover and load modules without knowing implementation details.
3. Contracts
Located in src/Contracts, they enforce module capabilities:
ModuleContract→ defines required metadata methods.HasRoutes,HasMigrations,HasViews,HasAssets→ optional feature interfaces.ManifestContract→ for objects that expose manifest data.
4. Support Classes
ModuleManifest→ value object holding module metadata.ModuleLoader→ utility to bootstrap and resolve modules.
5. Service Provider Integration
ModuleServiceProviderensures that modules can register services into Laravel’s container and lifecycle.
Package Structure
glugox/module/
├── src/
│ ├── Contracts/
│ │ ├── ModuleContract.php
│ │ ├── ManifestContract.php
│ │ ├── HasRoutes.php
│ │ ├── HasViews.php
│ │ ├── HasMigrations.php
│ │ └── HasAssets.php
│ ├── Support/
│ │ ├── ModuleManifest.php
│ │ └── ModuleLoader.php
│ ├── Module.php
│ └── ModuleServiceProvider.php
└── composer.json
Example Implementation
Defining a Module
use Glugox\Module\Module; use App\Providers\BillingServiceProvider; class BillingModule extends Module { public function id(): string { return 'company/billing'; } public function name(): string { return 'Billing'; } public function description(): string { return 'Invoices and payments'; } public function version(): string { return '1.0.0'; } public function capabilities(): array { return ['http:web', 'http:api']; } public function serviceProvider(): string { return BillingServiceProvider::class; } public function routesPath(): ?string { return __DIR__ . '/routes/web.php'; } }
Example Manifest
{
"id": "company/billing",
"name": "Billing",
"namespace": "Company\\Billing",
"description": "Invoices and payments",
"version": "1.0.0",
"capabilities": ["http:web", "http:api"]
}
How It Fits in the Ecosystem
glugox/module-generatorcreates modules that extend theModulebase class.glugox/orchestratorloads modules by reading their manifests and registering providers.- Main Laravel App → simply requires modules as composer packages and lets orchestrator manage them.
Benefits
- Standardization → Every module follows the same pattern.
- Reusability → Modules can be reused across multiple Laravel projects.
- Separation of Concerns → Clear split between contracts (in
glugox/module), orchestration (inglugox/orchestrator), and generation (inglugox/module-generator).
Next Steps
- Finalize the
ModuleContractand optional feature interfaces. - Improve
ModuleLoaderto handle different discovery strategies (filesystem, composer). - Document how modules interact with Laravel’s container and lifecycle in detail.