summaryrefslogtreecommitdiffstats
path: root/docs
diff options
context:
space:
mode:
author8ctopus <13252042+8ctopus@users.noreply.github.com>2019-10-10 03:33:03 +0500
committerzeripath <art27@cantab.net>2019-10-09 23:33:03 +0100
commite270896a834f9f73c25b3e27fe596d2ced55b414 (patch)
tree4b01645c76fa472d82e727855b5c729063ec651d /docs
parent5109d18b298235c09e75eb0d3e900e777ac786b2 (diff)
downloadgitea-e270896a834f9f73c25b3e27fe596d2ced55b414.tar.gz
gitea-e270896a834f9f73c25b3e27fe596d2ced55b414.zip
Doc updated list of supported webhooks and added example (#8388)
* Doc updated list of supported webhooks and added example * Replaced webhook password verification by signature verification
Diffstat (limited to 'docs')
-rw-r--r--docs/content/doc/features/webhooks.en-us.md82
1 files changed, 81 insertions, 1 deletions
diff --git a/docs/content/doc/features/webhooks.en-us.md b/docs/content/doc/features/webhooks.en-us.md
index 628afb7356..1a0a180e7a 100644
--- a/docs/content/doc/features/webhooks.en-us.md
+++ b/docs/content/doc/features/webhooks.en-us.md
@@ -17,7 +17,15 @@ menu:
Gitea supports web hooks for repository events. This can be found in the settings
page `/:username/:reponame/settings/hooks`. All event pushes are POST requests.
-The two methods currently supported are Gitea and Slack.
+The methods currently supported are:
+
+- Gitea
+- Gogs
+- Slack
+- Discord
+- Dingtalk
+- Telegram
+- Microsoft Teams
### Event information
@@ -104,3 +112,75 @@ X-Gitea-Event: push
}
}
```
+
+### Example
+
+This is an example of how to use webhooks to run a php script upon push requests to the repository.
+In your repository Settings, under Webhooks, Setup a Gitea webhook as follows:
+
+- Target URL: http://mydomain.com/webhook.php
+- HTTP Method: POST
+- POST Content Type: application/json
+- Secret: 123
+- Trigger On: Push Events
+- Active: Checked
+
+Now on your server create the php file webhook.php
+
+```
+<?php
+
+$secret_key = '123';
+
+// check for POST request
+if ($_SERVER['REQUEST_METHOD'] != 'POST') {
+ error_log('FAILED - not POST - '. $_SERVER['REQUEST_METHOD']);
+ exit();
+}
+
+// get content type
+$content_type = isset($_SERVER['CONTENT_TYPE']) ? strtolower(trim($_SERVER['CONTENT_TYPE'])) : '';
+
+if ($content_type != 'application/json') {
+ error_log('FAILED - not application/json - '. $content_type);
+ exit();
+}
+
+// get payload
+$payload = trim(file_get_contents("php://input"));
+
+if (empty($payload)) {
+ error_log('FAILED - no payload');
+ exit();
+}
+
+// get header signature
+$header_signature = isset($_SERVER['HTTP_X_GITEA_SIGNATURE']) ? $_SERVER['HTTP_X_GITEA_SIGNATURE'] : '';
+
+if (empty($header_signature)) {
+ error_log('FAILED - header signature missing');
+ exit();
+}
+
+// calculate payload signature
+$payload_signature = hash_hmac('sha256', $payload, $secret_key, false);
+
+// check payload signature against header signature
+if ($header_signature != $payload_signature) {
+ error_log('FAILED - payload signature');
+ exit();
+}
+
+// convert json to array
+$decoded = json_decode($payload, true);
+
+// check for json decode errors
+if (json_last_error() !== JSON_ERROR_NONE) {
+ error_log('FAILED - json decode - '. json_last_error());
+ exit();
+}
+
+// success, do something
+```
+
+There is a Test Delivery button in the webhook settings that allows to test the configuration as well as a list of the most Recent Deliveries.