activity_creator.module in Open Social 8.2
Same filename and directory in other branches
- 8.9 modules/custom/activity_creator/activity_creator.module
- 8 modules/custom/activity_creator/activity_creator.module
- 8.3 modules/custom/activity_creator/activity_creator.module
- 8.4 modules/custom/activity_creator/activity_creator.module
- 8.5 modules/custom/activity_creator/activity_creator.module
- 8.6 modules/custom/activity_creator/activity_creator.module
- 8.7 modules/custom/activity_creator/activity_creator.module
- 8.8 modules/custom/activity_creator/activity_creator.module
- 10.3.x modules/custom/activity_creator/activity_creator.module
- 10.0.x modules/custom/activity_creator/activity_creator.module
- 10.1.x modules/custom/activity_creator/activity_creator.module
- 10.2.x modules/custom/activity_creator/activity_creator.module
Activity Creator module file.
File
modules/custom/activity_creator/activity_creator.moduleView source
<?php
/**
* @file
* Activity Creator module file.
*/
use Drupal\message\Entity\Message;
use Drupal\Core\Cache\Cache;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Entity\Display\EntityViewDisplayInterface;
use Drupal\Core\Url;
use Drupal\activity_creator\Entity\Activity;
/**
* Activity statuses.
*/
const ACTIVITY_STATUS_RECEIVED = 1;
const ACTIVITY_STATUS_SEEN = 2;
const ACTIVITY_STATUS_READ = 3;
/**
* Returns the allowed values for the activity status field.
*
* @return array
* Return an array of allowed values for status field.
*/
function activity_creator_field_activity_status_allowed_values() {
$allowed_values = [
ACTIVITY_STATUS_RECEIVED => 'Received',
ACTIVITY_STATUS_SEEN => 'Seen',
ACTIVITY_STATUS_READ => 'Read',
];
return $allowed_values;
}
/**
* Returns the allowed values for the activity destinations field.
*
* @return array
* Return an array of allowed values for destinations field.
*/
function activity_creator_field_activity_destinations_allowed_values() {
$allowed_values = [
'stream_profile' => 'Stream (profile)',
'stream_home' => 'Stream (home)',
'stream_group' => 'Stream (group)',
'stream_explore' => 'Stream (explore)',
'notifications' => 'Notifications',
];
return $allowed_values;
}
/**
* Implements hook_ENTITY_TYPE_insert().
*/
function activity_creator_message_insert(Message $entity) {
if ($entity) {
// TODO Move all this logic to services (also in Queue).
$mid = $entity
->id();
$message_template_id = $entity
->getTemplate()
->id();
$actor = $entity
->getOwner()
->id();
$context = $entity
->get('field_message_context')
->getValue();
$destinations = $entity
->get('field_message_destination')
->getValue();
$related_object = $entity
->get('field_message_related_object')
->getValue();
$data = [
'mid' => $mid,
'message_template' => $message_template_id,
'actor' => $actor,
'context' => $context[0]['value'],
'destination' => $destinations,
'related_object' => $related_object,
'last_uid' => 0,
'status' => NULL,
];
$message_template = $entity
->getTemplate();
$activity_create_direct = $message_template
->getThirdPartySetting('activity_logger', 'activity_create_direct', NULL);
if ($activity_create_direct) {
$context_plugin_manager = \Drupal::service('plugin.manager.activity_context.processor');
/* @var $plugin \Drupal\activity_creator\Plugin\ActivityContextBase */
$plugin = $context_plugin_manager
->createInstance($data['context']);
$recipients = $plugin
->getRecipients($data, $data['last_uid'], 0);
$activity_factory = \Drupal::service('activity_creator.activity_factory');
if (!empty($recipients)) {
foreach ($recipients as $recipient) {
// Create a queue item for activity creation.
$activity_creator_data = [
'mid' => $data['mid'],
'message_template' => $data['message_template'],
'actor' => $data['actor'],
'context' => $data['context'],
'destination' => $data['destination'],
'related_object' => $data['related_object'],
'recipient' => $recipient,
];
$activity_factory
->createActivities($activity_creator_data);
}
}
else {
$activity_creator_data = [
'mid' => $data['mid'],
'message_template' => $data['message_template'],
'actor' => $data['actor'],
'context' => $data['context'],
'destination' => $data['destination'],
'related_object' => $data['related_object'],
];
$activity_factory
->createActivities($activity_creator_data);
}
}
else {
$queue = \Drupal::queue('activity_creator_logger');
$queue
->createItem($data);
}
}
}
/**
* Implements hook_views_data().
*/
function activity_creator_views_data() {
$data['activity']['activity_visibility_access_filter'] = [
'title' => t('Activity visibility access'),
'filter' => [
'title' => t('Activity visibility access'),
'help' => t('Enable activity access control.'),
'field' => 'field_visibility',
'id' => 'activity_visibility_access',
],
];
$data['activity']['activity_post_visibility_access_filter'] = [
'title' => t('Activity post visibility access'),
'filter' => [
'title' => t('Activity post visibility access'),
'help' => t('Enable activity access control for related post entities.'),
'field' => 'field_visibility',
'id' => 'activity_post_visibility_access',
],
];
$data['activity']['activity_profile_argument'] = [
'title' => t('Activity profile argument'),
'argument' => [
'title' => t('Activity profile argument'),
'help' => t('Activity profile context argument.'),
'id' => 'activity_profile_argument',
],
];
$data['activity']['activity_group_argument'] = [
'title' => t('Activity group argument'),
'argument' => [
'title' => t('Activity group argument'),
'help' => t('Activity group context argument.'),
'id' => 'activity_group_argument',
],
];
return $data;
}
/**
* Implements hook_theme().
*/
function activity_creator_theme() {
$items = [
'activity' => [
'render element' => 'elements',
'file' => 'activity.page.inc',
'template' => 'activity',
],
];
return $items;
}
/**
* Implements hook_theme_suggestions_HOOK().
*/
function activity_creator_theme_suggestions_activity(array $variables) {
$suggestions = [];
$activity = $variables['elements']['#activity'];
$sanitized_view_mode = strtr($variables['elements']['#view_mode'], '.', '_');
$suggestions[] = 'activity__' . $sanitized_view_mode;
$suggestions[] = 'activity__' . $activity
->id();
$suggestions[] = 'activity__' . $activity
->id() . '__' . $sanitized_view_mode;
return $suggestions;
}
/**
* Implements hook_entity_view().
*
* Mark notifications as read.
*
* TODO: Maybe this should be an event subscriber service
*/
function activity_creator_entity_view(array &$build, EntityInterface $entity, EntityViewDisplayInterface $display, $view_mode) {
if ($view_mode === 'full') {
$account = \Drupal::currentUser();
// @TODO Check if this entity is even specified in ActivityLoggerFactory
\Drupal::service('activity_creator.activity_notifications')
->markEntityNotificationsAsRead($account, $entity);
}
// Generate the output text for the user in his selected language.
if ($entity instanceof Activity && !empty($entity
->get('field_activity_message')->target_id)) {
$message = Message::load($entity
->get('field_activity_message')->target_id);
if ($message instanceof Message) {
// Get the text in the users language.
$output = \Drupal::service('activity_creator.activity_factory')
->getMessageText($message);
// Replace the old text with the correct one.
$build['field_activity_output_text'][0]['#text'] = $output[0];
}
}
}
/**
* Implements hook_preprocess_views_view_unformatted().
*/
function activity_creator_preprocess_views_view_unformatted(&$variables) {
$view = $variables['view'];
$view_name = $view->storage
->id();
if ($view_name == 'activity_stream_notifications') {
$notification_url = Url::fromRoute('view.activity_stream_notifications.page_1');
$variables['notification_url'] = $notification_url;
}
}
/**
* Implements hook_entity_update().
*
* Clear cache tags for related activities.
*/
function activity_creator_entity_update(EntityInterface $entity) {
_activity_creator_activity_for_entity_updater('update', $entity);
}
/**
* Implements hook_entity_delete().
*
* Delete activity items when related entities are deleted.
*/
function activity_creator_entity_delete(EntityInterface $entity) {
_activity_creator_activity_for_entity_updater('delete', $entity);
}
/**
* Update and or delete activities for given entity.
*
* @param string $action
* A string containing the action. Can be delete or update.
* @param \Drupal\Core\Entity\EntityInterface $entity
* The entity object which is updated or deleted.
*
* @TODO: When group is deleted delete activities where group is recipient.
* @TODO: When user is deleted delete activities where user is recipient.
* @TODO: Move this to a service.
*/
function _activity_creator_activity_for_entity_updater($action, EntityInterface $entity) {
if ($entity !== NULL) {
$entity_type = $entity
->getEntityTypeId();
$entity_id = $entity
->id();
if ($entity_type !== 'activity') {
$entity_query = \Drupal::entityQuery('activity');
$entity_query
->condition('field_activity_entity.target_id', $entity_id, '=');
$entity_query
->condition('field_activity_entity.target_type', $entity_type, '=');
$ids = $entity_query
->execute();
}
if ($entity_type == 'user' || $entity_type == 'group') {
$entity_query = \Drupal::entityQuery('activity');
$entity_query
->condition('field_activity_recipient_' . $entity_type, $entity_id, '=');
$ids = $entity_query
->execute();
}
if ($entity_type == 'group_content') {
/** @var \Drupal\group\Entity\GroupContent $group_content */
$group_content = $entity;
$linked_entity = $group_content
->getEntity();
$group = $group_content
->getGroup();
if ($linked_entity && $linked_entity
->getEntityTypeId() === 'node' && $group
->id()) {
$entity_query = \Drupal::entityQuery('activity');
$entity_query
->condition('field_activity_entity.target_id', $linked_entity
->id(), '=');
$entity_query
->condition('field_activity_entity.target_type', $linked_entity
->getEntityTypeId(), '=');
$entity_query
->condition('field_activity_recipient_group', $group
->id(), '=');
$ids = $entity_query
->execute();
}
}
if (empty($ids)) {
return;
}
if ($action === 'update') {
$tags = [];
foreach ($ids as $id) {
$tags[] = 'activity:' . $id;
}
Cache::invalidateTags($tags);
}
elseif ($action === 'delete') {
entity_delete_multiple('activity', $ids);
}
}
}
/**
* Implements hook_cron().
*/
function activity_creator_cron() {
// Empty activity stream queues.
activity_creator_empty_queue();
}
/**
* Function that empties the activity queues.
*/
function activity_creator_empty_queue() {
// Activity queues.
$queues = [
'activity_creator_activities',
'activity_creator_logger',
'activity_logger_message',
'activity_send_email_worker',
];
// The workermanager.
$workerManager = \Drupal::service('plugin.manager.queue_worker');
/*
* @var Drupal\Core\Queue\QueueFactory; $queue
*/
$queue = \Drupal::service('queue');
for ($i = 0; $i < 5; $i++) {
foreach ($workerManager
->getDefinitions() as $name => $info) {
if (in_array($name, $queues)) {
/** @var Drupal\Core\Queue\QueueInterface $worker */
$worker = $queue
->get($name);
/** @var \Drupal\Core\Queue\QueueWorkerInterface $queue_worker */
$queue_worker = $workerManager
->createInstance($name);
// Must contain items.
if ($worker
->numberOfItems() > 0) {
while ($item = $worker
->claimItem()) {
$queue_worker
->processItem($item->data);
$worker
->deleteItem($item);
}
}
}
}
}
}
Functions
Constants
Name | Description |
---|---|
ACTIVITY_STATUS_READ | |
ACTIVITY_STATUS_RECEIVED | Activity statuses. |
ACTIVITY_STATUS_SEEN |