summaryrefslogtreecommitdiff
path: root/app/Notification/ActivityStream.php
diff options
context:
space:
mode:
authorFrederic Guillot <fred@kanboard.net>2015-10-17 12:53:11 -0400
committerFrederic Guillot <fred@kanboard.net>2015-10-17 12:53:11 -0400
commit9153c6ff0ddb3170928d33599d9178e67ca466b6 (patch)
tree450891d77f14baf1df068d23609ff326345ef41f /app/Notification/ActivityStream.php
parent472f94efee77d8f47ece4ead7d36ee02e5df3e56 (diff)
Move ProjectActivitySubscriber to a new notification type
Diffstat (limited to 'app/Notification/ActivityStream.php')
-rw-r--r--app/Notification/ActivityStream.php58
1 files changed, 58 insertions, 0 deletions
diff --git a/app/Notification/ActivityStream.php b/app/Notification/ActivityStream.php
new file mode 100644
index 00000000..65ae64b1
--- /dev/null
+++ b/app/Notification/ActivityStream.php
@@ -0,0 +1,58 @@
+<?php
+
+namespace Kanboard\Notification;
+
+use Kanboard\Core\Base;
+
+/**
+ * Activity Stream Notification
+ *
+ * @package notification
+ * @author Frederic Guillot
+ */
+class ActivityStream 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)
+ {
+ if ($this->userSession->isLogged()) {
+
+ $this->projectActivity->createEvent(
+ $project['id'],
+ $event_data['task']['id'],
+ $this->userSession->getId(),
+ $event_name,
+ $event_data
+ );
+
+ // TODO: need to be moved to external plugins
+ foreach (array('slackWebhook', 'hipchatWebhook', 'jabber') as $model) {
+ $this->$model->notify(
+ $project['id'],
+ $event_data['task']['id'],
+ $event_name,
+ $event_data
+ );
+ }
+ }
+ }
+}