承接 ewk/laravel-modules 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

ewk/laravel-modules

最新稳定版本:v0.1.0

Composer 安装命令:

composer require ewk/laravel-modules

包简介

Manifest-driven Laravel module loader and lifecycle toolkit.

README 文档

README

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

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

Пакет покрывает 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). Опциональный MoonShine admin-UI управляет модулями из админки (docs/moonshine.md); установка/обновление через zip-upload в UI остаётся roadmap.

Quick Start

composer require ewk/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 Ewk\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
MoonShine Опциональный admin-UI управления модулями
Architecture Registry, cache, loaders, lifecycle
Loaders Справочник лоадеров и написание своего
Feature Toggles Runtime settings API
Logging Opt-in диагностический слой и каталог событий
Octane Octane worker contract и reload-операционка
CLI Реализованные Artisan-команды
AI Skills Поставляемые Agent Skills и modules:ai-install
Contributing Quality gates и PR rules

License

MIT

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-06-10

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固