Skip to main content
Version: 2024.3

Notifications

Feature allows to send notifications to user. Notifications adds to status bar new clickable icon, on click it opens new tab with all notifications, also it contains badge with unread notifications count.

When there's new notification for user, it shows as window with possibility to close it, mark as read or open details.

NotificationsNotificationsNotifications

User can use Share via Notifications button in order to open a new notification window and pre-fill the attachment field with desired element.

NotificationsNotificationsNotifications

Working with Notifications via API

Overview

For accessing and working with tags via API, take a look into Pimcore\Model\Notification\Service\NotificationService. Be aware that the service is tagged as internal and can change in future releases.

<?php
/**
* @throws UnexpectedValueException
*/
public function find(int $id): Notification
{
$notification = Notification::getById($id);

if (!$notification instanceof Notification) {
throw new UnexpectedValueException("Notification with the ID {$id} doesn't exists");
}

return $notification;
}

/**
* @param array<string, mixed> $filter
* @param array{offset?: int|string, limit?: int|string|null} $options
*
* @return array{total: int, data: Notification[]}
*
* @throws Exception
*/
public function findAll(array $filter = [], array $options = []): array
{
$listing = new Listing();

$filter = [...$filter, ...['isStudio' => 0]];

$conditions = [];
$conditionVariables = [];
foreach ($filter as $key => $value) {
if (isset($value['condition'])) {
$conditions[] = $value['condition'];
$conditionVariables[] = $value['conditionVariables'] ?? [];
} else {
$conditions[] = $key . ' = :' . $key;
$conditionVariables[] = [$key => $value];
}
}

$condition = implode(' AND ', $conditions);
$listing->setCondition($condition, array_merge(...$conditionVariables));

$listing->setOrderKey('creationDate');
$listing->setOrder('DESC');
$offset = $options['offset'] ?? 0;
$limit = $options['limit'] ?? null;

if (is_string($offset)) {
//TODO: Trigger deprecation
$offset = (int) $offset;
}
if (is_string($limit)) {
//TODO: Trigger deprecation
$limit = (int) $limit;
}

$this->beginTransaction();

$result = [
'total' => $listing->count(),
'data' => $listing->getItems($offset, $limit),
];

$this->commit();

return $result;
}

If you want to send some notifications to user:

<?php

use Pimcore\Model\Notification\Service\NotificationService;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;

public function defaultAction(
Request $request,
NotificationService $notificationService
): Response {
$element = Asset::getById(1); // Optional

$notificationService->sendToUser(
4, // User recipient
2, // User sender 0 - system
'Example notification',
'Example message',
$element // Optional linked element
);

// ...
}

If you want to send some notifications to users from group:

<?php

use Pimcore\Model\Notification\Service\NotificationService;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;

public function defaultAction(
Request $request,
NotificationService $notificationService
): Response {
$element = Asset::getById(1); // Optional

$notificationService->sendToGroup(
4, // Group recipient
2, // User sender 0 - system
'Example notification',
'Example message',
$element // Optional linked element
);

// ...
}

Configuration

The configuration allows enabling/disabling the Notifications menu in the toolbar and the check of new notifications (url: /admin/notification/find-last-unread). It is done in the pimcore_admin configuration in the notifications section.

default:

pimcore_admin:
notifications:
enabled: true
check_new_notification:
enabled: true
interval: 30

Example configurations:

  • Disable notifications menu and check of new unread notifications:
pimcore_admin:
notifications:
enabled: false
  • Disable only the check of new unread notifications:
pimcore_admin:
notifications:
check_new_notification:
enabled: false
  • Change interval to fetch new unread notifications (in seconds):
pimcore_admin:
notifications:
check_new_notification:
interval: 60