summaryrefslogtreecommitdiff
path: root/app/Notification/WebhookNotification.php
diff options
context:
space:
mode:
authorFrederic Guillot <fred@kanboard.net>2016-05-28 17:36:55 -0400
committerFrederic Guillot <fred@kanboard.net>2016-05-28 17:36:55 -0400
commitd6c1c1ea33de6386fabe7c9546bfae1c38d3b9e7 (patch)
treeee4f0a0d830c7019061204a1d659ff00ce6c29f5 /app/Notification/WebhookNotification.php
parent88ee691bb9c17bd6d2b93873ed789d2edc120b37 (diff)
Improve notification classes and move interface to core
Diffstat (limited to 'app/Notification/WebhookNotification.php')
-rw-r--r--app/Notification/WebhookNotification.php56
1 files changed, 56 insertions, 0 deletions
diff --git a/app/Notification/WebhookNotification.php b/app/Notification/WebhookNotification.php
new file mode 100644
index 00000000..25d59251
--- /dev/null
+++ b/app/Notification/WebhookNotification.php
@@ -0,0 +1,56 @@
+<?php
+
+namespace Kanboard\Notification;
+
+use Kanboard\Core\Base;
+use Kanboard\Core\Notification\NotificationInterface;
+
+/**
+ * Webhook Notification
+ *
+ * @package Kanboard\Notification
+ * @author Frederic Guillot
+ */
+class WebhookNotification extends Base implements NotificationInterface
+{
+ /**
+ * Send notification to a user
+ *
+ * @access public
+ * @param array $user
+ * @param string $event_name
+ * @param array $event_data
+ */
+ public function notifyUser(array $user, $event_name, array $event_data)
+ {
+ }
+
+ /**
+ * Send notification to a project
+ *
+ * @access public
+ * @param array $project
+ * @param string $event_name
+ * @param array $event_data
+ */
+ public function notifyProject(array $project, $event_name, array $event_data)
+ {
+ $url = $this->config->get('webhook_url');
+ $token = $this->config->get('webhook_token');
+
+ if (! empty($url)) {
+ if (strpos($url, '?') !== false) {
+ $url .= '&token='.$token;
+ } else {
+ $url .= '?token='.$token;
+ }
+
+ $payload = array(
+ 'event_name' => $event_name,
+ 'event_data' => $event_data,
+ );
+
+ $this->httpClient->postJson($url, $payload);
+ }
+ }
+}