dimitrienkov0/laravel-modules

There is no license information available for the latest version (1.1.0) of this package.

Manifest-driven Laravel module loader and lifecycle toolkit.

Maintainers

Package info

github.com/dimitrienkov/laravel-modules

pkg:composer/dimitrienkov0/laravel-modules

Statistics

Installs: 486

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

1.1.0 2026-03-22 09:42 UTC

This package is auto-updated.

Last update: 2026-06-04 07:03:08 UTC


README

Manifest-driven runtime для модулей в Laravel 12/13.

dimitrienkov0/laravel-modules помогает Laravel-приложению находить модули в настроенных директориях, валидировать module.json, сортировать модули по зависимостям и загружать enabled-модули через предсказуемый loader pipeline.

Текущий v2.0 core покрывает runtime loading, feature values, production registry cache, lifecycle-команды (make:module, modules:install, modules:update, modules:remove, modules:enable, modules:disable, modules:list, modules:optimize, modules:optimize-clear) и module-aware генераторы: native make:* --module для 22 артефактов плюс архитектурные make:use-case/action/query/dto/vo (см. docs/cli.md). Полноценный admin UI остаётся roadmap.

Quick Start

composer require dimitrienkov0/laravel-modules
php artisan vendor:publish --tag=modules-config
php artisan make:module blog

Проверка production cache:

php artisan modules:optimize

Требования

Компонент Версия
PHP 8.3+
Laravel 12 / 13
Optional admin bridge MoonShine 4
Optional routes bridge Inertia 2

Возможности

  • Manifest-first modules: immutable metadata и feature schema живут в module.json; mutable state и feature values - в state.json.
  • Dependency-aware registry: meta.dependencies сортируются и проверяются через Composer SemVer constraints.
  • Loader pipeline: 15 convention-based loaders загружают config, providers, migrations, routes, commands, policies, middleware и другие runtime paths.
  • Runtime feature API: FeatureRepositoryInterface читает актуальные settings.values из state.json.
  • Production cache: modules:optimize кеширует discovery в bootstrap/cache/modules.php, но не кеширует state и values.
  • Lifecycle toolkit: scaffold, install, update, remove, enable и disable работают через UseCase-классы с backup/rollback boundaries.
  • Opt-in диагностическое логирование: off by default; включается через MODULES_LOGGING=true и пишет structured discovery/cache/pipeline/lifecycle события на выбранный канал хоста для field-diagnostics (docs/logging.md).
  • Optional bridges: MoonShine и Inertia активируются только при наличии соответствующих пакетов.

Минимальный модуль

php artisan make:module blog

Команда создаёт структуру модуля, module.json, ServiceProvider stub и приватный state.json.

Минимальный module.json после scaffold:

{
  "schema_version": 1,
  "meta": {
    "name": "blog",
    "display_name": "Blog",
    "kind": "module",
    "group": "content",
    "version": "1.0.0"
  },
  "settings": {
    "schema": {}
  }
}

schema_version, meta.name, meta.kind и meta.version — обязательные; meta.group — необязательное (kebab-case группа для отображения в modules:list). Полный контракт — в docs/manifest.md.

storage/app/private/modules/blog/state.json:

{
  "enabled": true,
  "installed_at": "2026-05-23T14:12:00+00:00",
  "updated_at": "2026-05-23T14:12:00+00:00",
  "source": {
    "kind": "local",
    "installed_version": "1.0.0"
  },
  "settings": {
    "values": {}
  }
}

Feature Usage

Добавьте feature schema и values, как описано в docs/feature-toggles.md, затем читайте их через scoped repository:

<?php

declare(strict_types=1);

use DimitrienkoV\LaravelModules\Contracts\FeatureRepositoryInterface;

final readonly class PostController
{
    public function __construct(
        private FeatureRepositoryInterface $features,
    ) {
    }

    public function index(): void
    {
        $commentsEnabled = $this->features->getBool('blog', 'enable_comments');
    }
}

Документация

Раздел Описание
Getting Started Установка и первая проверка
Module Structure Поддерживаемые runtime-пути
Manifest Контракт module.json
Configuration Конфиг и routing options
Architecture Registry, cache, loaders, lifecycle
Feature Toggles Runtime settings API
Logging Opt-in диагностический слой и каталог событий
Octane Octane worker contract и reload-операционка
CLI Реализованные Artisan-команды
Contributing Quality gates и PR rules

License

MIT