mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 10:23:17 +00:00
312 lines
10 KiB
PHP
312 lines
10 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2014 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
use Alchemy\Phrasea\Application;
|
|
use Alchemy\Phrasea\Model\Entities\User;
|
|
use Doctrine\DBAL\Connection;
|
|
|
|
class eventsmanager_broker
|
|
{
|
|
protected $notifications = [];
|
|
protected $pool_classes = [];
|
|
|
|
/**
|
|
*
|
|
* @var Application
|
|
*/
|
|
protected $app;
|
|
|
|
public function __construct(Application $app)
|
|
{
|
|
$this->app = $app;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function start()
|
|
{
|
|
$iterators_pool = [
|
|
'event' => [
|
|
'eventsmanager_event_test'
|
|
],
|
|
'notify' => [
|
|
'eventsmanager_notify_autoregister',
|
|
'eventsmanager_notify_bridgeuploadfail',
|
|
'eventsmanager_notify_downloadmailfail',
|
|
'eventsmanager_notify_feed',
|
|
'eventsmanager_notify_order',
|
|
'eventsmanager_notify_orderdeliver',
|
|
'eventsmanager_notify_ordernotdelivered',
|
|
'eventsmanager_notify_push',
|
|
'eventsmanager_notify_register',
|
|
'eventsmanager_notify_uploadquarantine',
|
|
'eventsmanager_notify_validate',
|
|
'eventsmanager_notify_validationdone',
|
|
'eventsmanager_notify_validationreminder',
|
|
]
|
|
];
|
|
|
|
foreach ($iterators_pool as $type => $iterators) {
|
|
foreach ($iterators as $fileinfo) {
|
|
$classname = $fileinfo;
|
|
|
|
if ( ! class_exists($classname, true)) {
|
|
continue;
|
|
}
|
|
$this->pool_classes[$classname] = new $classname($this->app);
|
|
|
|
if ($type === 'notify' && $this->pool_classes[$classname])
|
|
$this->notifications[] = $classname;
|
|
}
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
public function notify($usr_id, $event_type, $datas, $mailed = false)
|
|
{
|
|
try {
|
|
$event_type = str_replace('eventsmanager_', '', $event_type);
|
|
|
|
$sql = 'INSERT INTO notifications (id, usr_id, type, unread, mailed, datas, created_on)
|
|
VALUES
|
|
(null, :usr_id, :event_type, 1, :mailed, :datas, NOW())';
|
|
|
|
$params = [
|
|
':usr_id' => $usr_id
|
|
, ':event_type' => $event_type
|
|
, ':mailed' => ($mailed ? 1 : 0)
|
|
, ':datas' => $datas
|
|
];
|
|
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute($params);
|
|
$stmt->closeCursor();
|
|
} catch (\Exception $e) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function get_notifications_as_array($page = 0)
|
|
{
|
|
$total = 0;
|
|
|
|
$sql = 'SELECT count(id) as total, sum(unread) as unread
|
|
FROM notifications WHERE usr_id = :usr_id';
|
|
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute([':usr_id' => $this->app->getAuthenticatedUser()->getId()]);
|
|
$row = $stmt->fetch(PDO::FETCH_ASSOC);
|
|
$stmt->closeCursor();
|
|
|
|
if ($row) {
|
|
$total = $row['total'];
|
|
}
|
|
|
|
$n = 10;
|
|
|
|
$sql = 'SELECT * FROM notifications
|
|
WHERE usr_id = :usr_id
|
|
ORDER BY created_on DESC
|
|
LIMIT ' . ((int) $page * $n) . ', ' . $n;
|
|
|
|
$data = ['notifications' => [], 'next' => ''];
|
|
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute([':usr_id' => $this->app->getAuthenticatedUser()->getId()]);
|
|
$rs = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
$stmt->closeCursor();
|
|
|
|
foreach ($rs as $row) {
|
|
$type = 'eventsmanager_' . $row['type'];
|
|
$json = @json_decode($row['datas'], true);
|
|
|
|
if (json_last_error() !== JSON_ERROR_NONE) {
|
|
continue;
|
|
}
|
|
|
|
$content = $this->pool_classes[$type]->datas($json, $row['unread']);
|
|
|
|
if ( ! isset($this->pool_classes[$type]) || count($content) === 0) {
|
|
$sql = 'DELETE FROM notifications WHERE id = :id';
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute([':id' => $row['id']]);
|
|
$stmt->closeCursor();
|
|
continue;
|
|
}
|
|
|
|
$date_key = str_replace('-', '_', substr($row['created_on'], 0, 10));
|
|
$display_date = $this->app['date-formatter']->getDate(new DateTime($row['created_on']));
|
|
|
|
if ( ! isset($data['notifications'][$date_key])) {
|
|
$data['notifications'][$date_key] = [
|
|
'display' => $display_date
|
|
, 'notifications' => []
|
|
];
|
|
}
|
|
|
|
$data['notifications'][$date_key]['notifications'][$row['id']] = [
|
|
'classname' => $content['class']
|
|
, 'time' => $this->app['date-formatter']->getTime(new DateTime($row['created_on']))
|
|
, 'icon' => '<img src="' . $this->pool_classes[$type]->icon_url() . '" style="vertical-align:middle;width:16px;margin:2px;" />'
|
|
, 'id' => $row['id']
|
|
, 'text' => $content['text']
|
|
];
|
|
}
|
|
|
|
if (((int) $page + 1) * $n < $total) {
|
|
$data['next'] = '<a href="#" class="notification__print-action" data-page="' . ((int) $page + 1) . '">' . $this->app->trans('charger d\'avantages de notifications') . '</a>';
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function get_unread_notifications_number()
|
|
{
|
|
$total = 0;
|
|
|
|
$sql = 'SELECT count(id) as total
|
|
FROM notifications
|
|
WHERE usr_id = :usr_id AND unread="1"';
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute([':usr_id' => $this->app->getAuthenticatedUser()->getId()]);
|
|
$row = $stmt->fetch(PDO::FETCH_ASSOC);
|
|
$stmt->closeCursor();
|
|
|
|
if ($row) {
|
|
$total = $row['total'];
|
|
}
|
|
|
|
return $total;
|
|
}
|
|
|
|
public function get_notifications()
|
|
{
|
|
$unread = 0;
|
|
|
|
$sql = 'SELECT count(id) as total, sum(unread) as unread
|
|
FROM notifications WHERE usr_id = :usr_id';
|
|
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute([':usr_id' => $this->app->getAuthenticatedUser()->getId()]);
|
|
$row = $stmt->fetch(PDO::FETCH_ASSOC);
|
|
$stmt->closeCursor();
|
|
|
|
if ($row) {
|
|
$unread = $row['unread'];
|
|
}
|
|
|
|
if ($unread < 3) {
|
|
$sql = 'SELECT * FROM notifications
|
|
WHERE usr_id = :usr_id ORDER BY created_on DESC LIMIT 0,4';
|
|
} else {
|
|
$sql = 'SELECT * FROM notifications
|
|
WHERE usr_id = :usr_id AND unread="1" ORDER BY created_on DESC';
|
|
}
|
|
|
|
$ret = [];
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute([':usr_id' => $this->app->getAuthenticatedUser()->getId()]);
|
|
$rs = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
$stmt->closeCursor();
|
|
|
|
foreach ($rs as $row) {
|
|
$type = 'eventsmanager_' . $row['type'];
|
|
if ( ! isset($this->pool_classes[$type])) {
|
|
continue;
|
|
}
|
|
$data = @json_decode($row['datas'], true);
|
|
|
|
if (json_last_error() !== JSON_ERROR_NONE) {
|
|
continue;
|
|
}
|
|
|
|
$datas = $this->pool_classes[$type]->datas($data, $row['unread']);
|
|
|
|
if ( ! isset($this->pool_classes[$type]) || count($datas) === 0) {
|
|
$sql = 'DELETE FROM notifications WHERE id = :id';
|
|
$stmt = $this->app->getApplicationBox()->get_connection()->prepare($sql);
|
|
$stmt->execute([':id' => $row['id']]);
|
|
$stmt->closeCursor();
|
|
continue;
|
|
}
|
|
|
|
$ret[] = array_merge(
|
|
$datas
|
|
, [
|
|
'created_on' => $this->app['date-formatter']->getPrettyString(new DateTime($row['created_on']))
|
|
, 'icon' => $this->pool_classes[$type]->icon_url()
|
|
, 'id' => $row['id']
|
|
, 'unread' => $row['unread']
|
|
]
|
|
);
|
|
}
|
|
|
|
return $ret;
|
|
}
|
|
|
|
public function read(Array $notifications, $usr_id)
|
|
{
|
|
if (count($notifications) == 0) {
|
|
return false;
|
|
}
|
|
|
|
/** @var Connection $connection */
|
|
$connection = $this->app->getApplicationBox()->get_connection();
|
|
$builder = $connection->createQueryBuilder();
|
|
$builder
|
|
->update('notifications')
|
|
->set('unread', '0')
|
|
->where(
|
|
$builder->expr()->eq('usr_id', ':usr_id'),
|
|
$builder->expr()->in('id', [':notifications'])
|
|
)
|
|
->setParameters(
|
|
[
|
|
'usr_id' => $usr_id,
|
|
'notifications' => $notifications,
|
|
],
|
|
[
|
|
'usr_id' => PDO::PARAM_INT,
|
|
'notifications' => Connection::PARAM_INT_ARRAY,
|
|
]
|
|
)
|
|
->execute()
|
|
;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function list_notifications_available(User $user)
|
|
{
|
|
$personal_notifications = [];
|
|
|
|
foreach ($this->notifications as $notification) {
|
|
if (!$this->pool_classes[$notification]->is_available($user)) {
|
|
continue;
|
|
}
|
|
$group = $this->pool_classes[$notification]->get_group();
|
|
$group = $group === null ? $this->app->trans('Notifications globales') : $group;
|
|
|
|
$personal_notifications[$group][] = [
|
|
'name' => $this->pool_classes[$notification]->get_name(),
|
|
'id' => $notification,
|
|
'description' => $this->pool_classes[$notification]->get_description(),
|
|
'subscribe_emails' => true,
|
|
];
|
|
}
|
|
|
|
return $personal_notifications;
|
|
}
|
|
}
|