承接 jblaak/php-modules 相关项目开发

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

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

jblaak/php-modules

最新稳定版本:1.3.0

Composer 安装命令:

composer require jblaak/php-modules

包简介

README 文档

README

Declare clear dependencies within your application by defining which modules have access to other parts of your application.

Installation

This package will soon be published on Packagist, however it is still in development.

Features

Run module checks on your codebase using the test command

./vendor/bin/modules test

Generate a dependency graph, make sure you have installed GraphViz for this.

./vendor/bin/modules graph

Defining modules

Your modules.php file in the root of your project will be where your configuration will live. This file should return an instance of PhpModules\Lib\Modules.

Let's say we have a module in the namespace App\Http that depends on App\Persistence, we can define this as follows:

<?php

$persistence = PhpModules\Lib\Module::create('App\Persistence');
$http = PhpModules\Lib\Module::create('App\Http', [$persistence]);

return Modules::builder('./src')->register([$persistence, $http])

It is by design that you can't create cyclic dependencies since this is the thing that we are trying to avoid with this design pattern.

Strict modules

Explicitly define which classes are exported from your modules. Most modules will have an explicit public api which internally might have a lot of helper classes and other logic. For example a App\Persistence module might have a App\Persistence\PersistedUser and App\Persistence\UserRepository as public api but might want to hide the App\Persistence\Drivers\MySQLDriver to prevent other modules meddling with database configurations.

Define strict modules using Module::strict:

<?php

$persistence = PhpModules\Lib\Module::strict('App\Persistence');
$http = PhpModules\Lib\Module::strict('App\Http', [$persistence]);

return Modules::builder('./src')->register([$persistence, $http])

Mark classes as public using PHPDoc:

/**
 * @public
 */
class PersistedUser {}

Working with external dependencies or legacy codebases

Even though it is encouraged to try and be as explicit as possible in defining your dependencies, external dependencies (such as frameworks) or legacy codebases require a lot of configuration to get started.

To allow importing from parts of your application not yet defined as a module, or external libraries we can add ->allowUndefinedModules() to our Modules configuration.

For example, your App\Persistence layer might depend on Laravel's Eloquent (if you're into such thing) without you having to explicitly declare it:

<?php

$persistence = PhpModules\Lib\Module::create('App\Persistence');
$http = PhpModules\Lib\Module::create('App\Http', [$persistence]);

return Modules::builder('./src') 
    ->allowUndefinedModules()
    ->register([$persistence, $http])

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: Unknown
  • 更新时间: 2022-01-17