apility/plugins 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

apility/plugins

最新稳定版本:v0.0.2

Composer 安装命令:

composer require apility/plugins

包简介

Laravel plugin architecture

README 文档

README

This package provides a simple way of making your Laravel application modular. It implments a simple plugin architecture that allows you to create plugins and register them in a shared repository.

You can then use feature detection through interfaces or traits to registered plugins.

The plugins are an abstraction around Laravel's service providers, so you can use all the features of service providers in your plugins.

Installation

You can install the package via composer:

composer require apility/plugins

Usage

Creating a plugin

To create a plugin, you need to create a class that implements the Apility\Plugins\Contracts\Plugin interface.

The simplest way to do this is to extend from the abstract Apility\Plugins\Plugin class.

use Apility\Plugins\Plugin;

class MyPlugin extends Plugin
{
    public function register()
    {
        // Here you can perform any registration that
        // you would normally do in a service provider.
    }
}

Registering a plugin

To register a plugin, you need to register them in the plugin repository.

The plugin repository is a singleton that implements the Apility\Plugins\Contracts\PluginRepository interface.

The recommended way to interface with the repository is through the Apility\Plugins\Facades\Plugin facade.

use Apility\Plugins\Facades\Plugin;

Plugin::register(MyPlugin::class);

Using a plugin

The main purpose of this package is to allow you to use plugins in your application through feature detection.

You can use the Apility\Plugins\Facades\Plugin facade to resolve plugins based on features (interfaces or traits).

use Apility\Plugins\Facades\Plugin;
use Apility\Plugins\Plugin as BasePlugin;

interface MyFeature
{
    public function doSomething();
}

class MyPlugin extends BasePlugin implements MyFeature
{
    public function doSomething()
    {
        return 'Hello world!';
    }
}

$plugins = Plugin::all(MyFeature::class);

foreach ($plugins as $plugin) {
    /** @var MyFeature $plugin */
    echo $plugin->doSomething();
}

Other ways of using plugins

use Apility\Plugins\Facades\Plugin;

// Get the number of registered plugins
$pluginCount = Plugin::count();

// Get the number of registered plugins by type
$pluginCount = Plugin::count(MyPlugin::class);

// Check if a plugin is registered
$pluginRegistered = Plugin::has(MyPlugin::class);

// Get all plugins
$plugins = Plugin::all();

// Get all plugins by type
$plugins = Plugin::all(MyPlugin::class);

// Get the first registered plugin
$plugin = Plugin::first();

// Get a plugin by type
$plugin = Plugin::first(MyPlugin::class);

Generating a plugin

You can use the make:plugin command to generate a plugin.

php artisan make:plugin MyPlugin

Generating a plugin with Policy

You can use the --policy option to generate a plugin with a corresponsing policy.

php artisan make:plugin MyPlugin --policy

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-01-19

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固