This repository has been archived by the owner on Feb 2, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 59
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
241 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,242 @@ | ||
# Webhook | ||
# Magento 2 Webhook Free Extension | ||
|
||
[Mageplaza Webhook](https://www.mageplaza.com/magento-2-webhook/) for Magento 2 supports online store to send an API request via a webhook to a configurable destination (URL) when specific trigger events take place. Webhook a very useful and necessary tool which allows stores to update instant and real-time notifications. | ||
|
||
|
||
## 1. Documentation | ||
|
||
- [Installation guide](https://www.mageplaza.com/install-magento-2-extension/) | ||
- [User guide](https://docs.mageplaza.com/facebook-plugin/index.html) | ||
- [Introduction page](http://www.mageplaza.com/magento-2-webhook/) | ||
- [Contribute on Github](https://github.com/mageplaza/magento-2-webhook) | ||
- [Get Support](https://github.com/mageplaza/magento-2-webhook/issues) | ||
|
||
## 2. FAQs | ||
|
||
**Q: I got error: Mageplaza_Core has been already defined** | ||
|
||
A: Read solution [here](https://github.com/mageplaza/module-core/issues/3) | ||
|
||
**Q: How can I set time for abandoned cart?** | ||
|
||
A: This can be done easily from admin backend. The time will be calculated by hours. . | ||
|
||
**Q: I am using CRM system. Does this extension support to send data to this system?** | ||
|
||
A: Yes, absolutely. You just need to create hooks with specific trigger events you want to send data to CRM, then insert the CRM payload URL from the admin backend. | ||
|
||
**Q: If a request of a hook fails, how can I get notice?** | ||
|
||
A: Please enable the function “Alert on Error” and add the emails of recipients you wish. | ||
|
||
|
||
## 3. How to install Webhook extension for Magento 2 | ||
|
||
Run the following command in Magento 2 root folder: | ||
|
||
``` | ||
composer require mageplaza/module-webhook | ||
php bin/magento setup:upgrade | ||
php bin/magento setup:static-content:deploy | ||
``` | ||
## 4. Highlight features | ||
|
||
### Send API requests when specific events occur | ||
|
||
|
||
Webhook quickly detect any updates of stores and send API requests to other servers or applications right when the specific events take place. The hooks can be created based on such events as below: | ||
|
||
- New Order/ Invoice/ Shipment/ Credit Memo | ||
- New Order Comment | ||
- New/ Update/ Delete Customer | ||
- New/ Update/ Delete Product | ||
- New/ Update/ Delete Category | ||
- Customer Login | ||
- Abandoned Cart | ||
|
||
|
||
![Imgur](https://i.imgur.com/fgA2Y8r.png) | ||
|
||
### Send API requests when cart abandonment happens | ||
|
||
One of the typical features of Webhook is to allow sending the notice at the exact time when cart abandonment happens. | ||
|
||
This is really practical in stores with Sales and Customer Care departments which need this information to keep up with customers’ behaviors. | ||
|
||
![Imgur](https://i.imgur.com/37lI90u.png) | ||
|
||
### Send leads/customer data to CRM or Email Marketing tools | ||
|
||
![Imgur](https://i.imgur.com/SuRp9eA.png) | ||
|
||
Webhook is a supportive tool to CRM or Email Marketing systems used in e-commerce businesses. The data of customers or orders or any related updates is necessary to be sent instantly to these systems. Then, the stores can appoint quickly sales actions accordingly. | ||
|
||
### Log requests and response | ||
|
||
Status and error messages of hooks can be updated quickly via hook logs. Admin can quickly preview the response of Log ID easily. | ||
|
||
![Imgur](https://i.imgur.com/Zqa95iV.png) | ||
|
||
## 5. More features | ||
|
||
### Send alerts | ||
|
||
Notices of error requests sent via emails. | ||
|
||
### Auto-clear logs | ||
|
||
Clean logs daily when the total reaches a specific number. | ||
|
||
### Resend requests | ||
|
||
Resend replaced requests after fixing errors. | ||
|
||
|
||
## 6. Full features list | ||
|
||
### General Configuration | ||
- Enable/ Disable the module | ||
- Set time to send abandoned carts notice | ||
- Send alert emails when errors occur | ||
- Choose email template | ||
- Set total number for logs | ||
- Clean logs on a daily basis | ||
|
||
### Manage Hooks | ||
- Set name for a new hook | ||
- Set status, store view, priority for the hook | ||
- Input Payload URL | ||
- Select Method for sending requests | ||
- Input Header for the hook | ||
- Select content type with 4 choices | ||
- Insert variables to the body and preview | ||
- Manage hooks via a grid | ||
|
||
### Hook Logs | ||
- View all status, entity, message of logs | ||
- View error messages of logs | ||
- Select action for a log: Preview response or Replay (with fixed logs) | ||
|
||
|
||
## 7. User guide | ||
|
||
### 7.1 How to configure | ||
|
||
Login to the **Magento Admin**, choose `Store > Settings > Configuration > Mageplaza Extensions > Webhook`. | ||
|
||
![Imgur](https://i.imgur.com/lb28XMh.png) | ||
|
||
- **Enable**: Select `Yes` to enable the module and `No` to disable. | ||
- **Abandoned Cart After (minutes)**: Set minutes for Abandoned Cart. Recommend period time: 1, 6, 10, 12, 24 | ||
- **Keep logs**: Automatically clean log if it reaches this number. It will be done daily. | ||
- **Alert on Error**: Select “Yes” to send error notice via emails. To avoid sending to spam box, [SMTP](https://www.mageplaza.com/magento-2-smtp/) should be installed. | ||
|
||
|
||
![Imgur](https://i.imgur.com/j4ZnDaI.png) | ||
|
||
- **Send to**: Input email addresses to receive error notice. | ||
- **Email Template**: Follow `Marketing > Email Templates > Add New Template` to create your wished templates. You can select Default Mageplaza Webhook Email Template(Default). | ||
|
||
|
||
### 7.2 Manage Hook | ||
|
||
#### Grid | ||
|
||
From the **Admin Panel**, go to `Mageplaza > Webhook > Manage Hooks`. | ||
|
||
![Imgur](https://i.imgur.com/0kJFVFW.png) | ||
|
||
- The grid includes the main hook information: Name, Status, Store View, Entity, Created Date và Update Date,... | ||
- Admin can select actions: | ||
- **Delete**: Delete a hook | ||
- **Change status**: Select `Enable` to activate the hook. | ||
- **Edit**: Edit the hook information. | ||
- Besides, admin can change status, store view right on the Grid. | ||
- Choose `Add new` button to select **Trigger events** (New Order, New Product, Update Product, Delete Product,...) to Create New Hook và sending to other servers. | ||
|
||
### Create a Hook | ||
|
||
Select **Trigger events** (New Order, New Product, Update Product, Delete Product,...) to create new Hook | ||
|
||
|
||
![Imgur](https://i.imgur.com/5fnfrNb.gif) | ||
|
||
![Imgur](https://i.imgur.com/3JHzhFx.png) | ||
|
||
- **Name**: Set name for a new hook. This will be used when sending emails to customers. | ||
- **Status**: Select“ Enable” to activate the hook. | ||
- **Store View**: Select store view which the hook displays. | ||
- **Priority**: Set priority for the hook. The smaller number, the higher priority. | ||
|
||
|
||
![Imgur](https://i.imgur.com/lhaspGa.gif) | ||
|
||
- **Payload URL**: | ||
|
||
- Select **Insert Variable** button to insert variable. For example: Method **POST**: https://domain.freshsales.io/api/leads, **GET**: https://domain.freshsales.io/leads/view/4000831345, or https://domain.freshsales.io/leads/view/4000831345new_shipment={inserted variable} | ||
|
||
- Domain is the API account name. To sign up API account, follow the link: https://www.freshworks.com/freshsales-crm/. | ||
Find more about API [here](https://www.freshsales.io/api/#introduction). | ||
|
||
- This is a required field, not allow leaving blank | ||
|
||
- **Method** : Select method to send HTTP request. If leave this blank, the default method will be GET | ||
|
||
- GET: get data from the server | ||
- POST: create new object | ||
- PUT: Update the object | ||
- DELETE: Delete the object. | ||
- HEAD: the same as GET but not require body. | ||
- CONNECT: Converts the requested connection into a transparent TCP / IP tunnel, usually to facilitate SSL encryption (HTTPS) through an unencrypted HTTP proxy. | ||
- OPTIONS: Describe the options. An OPTIONS request should return data describing what other methods and operations the server supports at certain URLs. | ||
- TRACE: Repeat the request so that customers can see any changes or additions (if any) that have been made by the intermediate servers. | ||
- PATCH: Apply a modified part to an object. | ||
|
||
- **Authentication**: Select the type of data access authentication you want from the server. When you submit a request, you typically have to include parameters to make sure the request has access and returns the data you want. You should leave this field blank to limit access. | ||
|
||
![Imgur](https://i.imgur.com/C9mvIJi.png) | ||
|
||
- **Basic**: Display 2 Username and Password fields. Fill in the information to authenticate access. | ||
|
||
`Note`: In the process of being strictly enforced throughout the entire data cycle to SSL for security, authentication is transmitted over unsafe lines. | ||
|
||
- **Digest**: Fill out some credentials below: | ||
|
||
|
||
![Imgur](https://i.imgur.com/TbH4AvX.png) | ||
|
||
|
||
|
||
- **Headers**: Click Add button to add the values of headers such as **Name** and **Value** to be seen as an API. For example, Name is Authorization, Value is Token token= “Your API Key” | ||
|
||
- **Content-type**: Select the content type to send the data. For Method GET you can leave this field blank. | ||
|
||
![Imgur](https://i.imgur.com/CKSNQkS.png) | ||
|
||
- **Body**: For methods like POST or PUT, you need to add content to the body section to send the request. Click `Insert Variable` to select the variable. | ||
|
||
### 7.3 Hook Logs | ||
|
||
From the Admin Panel, go to `Mageplaza > Webhook > Logs` | ||
|
||
This section will record Webhooks change logs such as Name, Status, Entity, Message, etc. | ||
|
||
![Imgur](https://i.imgur.com/b89rx5I.png) | ||
|
||
#### View logs | ||
|
||
Click view to view the log details | ||
|
||
![Imgur](https://i.imgur.com/yCsaTIO.png) | ||
|
||
## Installation guide library | ||
|
||
You need to run the following command to install the library: | ||
|
||
``` | ||
composer require liquid/liquid | ||
``` | ||
|
||
|
||
|