PHPackages                             snr/plugin - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Framework](/categories/framework)
4. /
5. snr/plugin

ActiveLibrary[Framework](/categories/framework)

snr/plugin
==========

Реализует систему типов (плагинов), классы которых помечаются аннотациями или атрибутами (вдохновлено Plugin API Drupal 8)

1.0.0(8mo ago)0371PHPPHP &gt;=7.3

Since Sep 6Pushed 8mo agoCompare

[ Source](https://github.com/semahinn/plugin)[ Packagist](https://packagist.org/packages/snr/plugin)[ RSS](/packages/snr-plugin/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (1)Dependencies (6)Versions (2)Used By (1)

Описание
--------

[](#описание)

Позволяет разработчикам описывать свои собственные типы бизнес сущностей. Так, можно создать класс, пометить его специальной аннотацией и система "распознает" его как один из типов вашей сущности. Далее с помощью встроенного класса менеджера можно создавать экземпляры этих классов.

Установка
---------

[](#установка)

```
composer require snr/plugin
```

Использование
-------------

[](#использование)

Все примеры смотрите в tests\\PluginManagerTest.php

1. Сначала нужно определить свой "Менеджер плагинов". Создайте класс, наследующий класс DefaultPluginManager, как это сделано в примере - классе TestPluginManager.
2. Так, в конструкторе TestPluginManager мы передаём базовому классу: папку, где будут классы экземпляров (параметр subdir); класс этих экземпляров (параметр plugin\_interface); класс для аннотации (plugin\_definition\_annotation\_name).
3. Определить папку, где у вас будут находиться классы ваших типов (плагинов). В тестовом примере это папка Plugin. У вас может быть любая другая. Передаётся через параметр 'subdir' конструктора DefaultPluginManager'а.
4. Создать свой класс аннотации для экземпляров или использовать класс Plugin, который идёт по умолчанию. Передаётся через параметр 'plugin\_definition\_annotation\_name' конструктора DefaultPluginManager'а.
5. Создать свой интерфейс для экземпляров, примером является интерфейс TestPluginInterface. Передаётся через параметр 'plugin\_interface' конструктора DefaultPluginManager'а.
6. Создать свои классы, каждый из которых описывает один из типов экземпляров. В тестовм примере это класс TestPlugin.
7. В коде создать экземпляр вашего "Менеджера плагинов". Вызвать его метод createInstance, получив экземпляр нужного вам класса. См. пример в PluginManagerTest.php.

###  Health Score

27

—

LowBetter than 49% of packages

Maintenance60

Regular maintenance activity

Popularity7

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity30

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

255d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/7efda00f5df57e9f68d68a1b781c71a9b4b11c274592d91844689020a19fb4bd?d=identicon)[snr](/maintainers/snr)

---

Top Contributors

[![semahinn](https://avatars.githubusercontent.com/u/62962326?v=4)](https://github.com/semahinn "semahinn (1 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/snr-plugin/health.svg)

```
[![Health](https://phpackages.com/badges/snr-plugin/health.svg)](https://phpackages.com/packages/snr-plugin)
```

###  Alternatives

[sulu/sulu

Core framework that implements the functionality of the Sulu content management system

1.3k1.3M152](/packages/sulu-sulu)[silverstripe/framework

The SilverStripe framework

7213.5M2.5k](/packages/silverstripe-framework)[ec-cube/ec-cube

EC-CUBE EC open platform.

78527.0k1](/packages/ec-cube-ec-cube)[drupal/core-recommended

Locked core dependencies; require this project INSTEAD OF drupal/core.

6939.5M343](/packages/drupal-core-recommended)[contao/core-bundle

Contao Open Source CMS

1231.6M2.4k](/packages/contao-core-bundle)[neos/flow

Flow Application Framework

862.0M451](/packages/neos-flow)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
