定制 degordian/yii2-webhooks 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

degordian/yii2-webhooks

最新稳定版本:1.0.1

Composer 安装命令:

composer require degordian/yii2-webhooks

包简介

Yii2 extension for webhooks

README 文档

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

Image of webhook index page

Image of webhook-log index page

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

统计信息

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

GitHub 信息

  • Stars: 10
  • Watchers: 17
  • Forks: 5
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-11-30