degordian / yii2-webhooks
Yii2 extension for webhooks
Installs: 6 836
Dependents: 0
Suggesters: 0
Security: 0
Stars: 10
Watchers: 17
Forks: 5
Open Issues: 4
Type:yii2-extension
pkg:composer/degordian/yii2-webhooks
Requires
- yiisoft/yii2: ^2.0@dev
- yiisoft/yii2-httpclient: ~2.0.0
Requires (Dev)
- codeception/codeception: 2.5.x-dev
This package is not auto-updated.
Last update: 2025-10-15 17:12:32 UTC
README
Extension for creating and using web-hooks in yii2.
Description
Add webhooks and attach them to ActiveRecord objects' events to trigger HTTP requests to external systems
(3rd party services, your own applications etc.).
Use case example
Let's assume that inside your project you have an Example class which extends ActiveRecord.
If you want to trigger a webhook every time a new Example record is created, you will create a new Webhook record,
and assign it to your Example class.
You do this by setting the event attribute of the Webhook record to value of app\models\Example::EVENT_AFTER_CREATE.
You also set the webhook url and method values. For example http://api.service.com and POST.
Now, every time a new Example record is created inside your project, your api service receives an
http request with the Example object attributes.
Installation
The preferred way to install this extension is through composer.
Run composer installation.
composer require --prefer-dist degordian/yii2-webhooks "dev-master"
Setup
Run the migration. It creates the webhook and webhook_log tables.
php yii migrate --migrationPath=@degordian/webhooks/migrations
The extension needs to be bootstrapped:
'bootstrap' => [ // ... 'webhooks' ],
Add the module to the config:
'modules' => [ // ... 'webhooks' => [ 'class' => 'degordian\webhooks\Module', ], ],
Usage
Webhooks
Create a new webhook by navigating to the webhooks module: index.php?r=webhooks/webhook/create
You can use the predefined events from BaseActiveRecord class, e.g. EVENT_AFTER_INSERT or you can use your own events, e.g. app\models\Example::EVENT_EXAMPLE.
User generated events
When triggering your custom event, make sure you send the instantiated model like in the following code:
Event::trigger(Example::class, Example::EVENT_EXAMPLE, new Event(['sender' => $model]));
Logger
Extension logs every triggered webhook with its http request and response.
Logs are available at index.php/webhooks?r=/webhook-log/index
Implementing your own EventDispatcher
You can add your own implementation of the event dispatcher to fit your needs. It must implement EventDispatcherInterface.
Config needs to be updated accordingly:
'modules' => [ // ... 'webhooks' => [ 'class' => 'degordian\webhooks\Module', 'eventDispatcherComponentClass' => 'app\components\MyDispatcher', ], ],
Implementing your own Webhook
TBD
Screenshots
Contributing
Your local setup should have this repository and an existing yii2 project (preferably a clean yii2 template).
Link the repo to your project by adding it to your project's composer.json file:
"repositories": [
{
"type": "path",
"url": "../yii2-webhooks"
}
]
Install it to the project using composer:
composer require --prefer-dist degordian/yii2-webhooks "*"
You can edit the files from within you project, directly in your vendor folder, for it is much more convenient that way.
Credits
This extension is created and maintained by Bornfight.
License
TBD

