PostVisibilityAccess.php in Open Social 10.0.x
Same filename and directory in other branches
- 8.9 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8.2 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8.3 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8.4 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8.5 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8.6 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8.7 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 8.8 modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 10.3.x modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 10.1.x modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
- 10.2.x modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.php
Namespace
Drupal\social_post\Plugin\views\filterFile
modules/social_features/social_post/src/Plugin/views/filter/PostVisibilityAccess.phpView source
<?php
namespace Drupal\social_post\Plugin\views\filter;
use Drupal\Core\Database\Query\Condition;
use Drupal\Core\Form\FormStateInterface;
use Drupal\views\Plugin\views\filter\FilterPluginBase;
/**
* Filters post based on visibility settings.
*
* @ingroup views_filter_handlers
*
* @ViewsFilter("post_visibility_access")
*/
class PostVisibilityAccess extends FilterPluginBase {
/**
* {@inheritdoc}
*/
public function adminSummary() {
}
/**
* {@inheritdoc}
*/
protected function operatorForm(&$form, FormStateInterface $form_state) {
}
/**
* {@inheritdoc}
*/
public function canExpose() {
return FALSE;
}
/**
* Currently use similar access as for the entity.
*
* Probably want to extend this to entity access based on the node grant
* system when this is implemented.
* See https://www.drupal.org/node/777578
*/
public function query() {
$account = $this->view
->getUser();
$this->query
->addTable('post__field_visibility');
$and_condition = new Condition('AND');
$should_add_where_clause = FALSE;
if (!$account
->hasPermission('view public posts')) {
$and_condition
->condition('post__field_visibility.field_visibility_value', '1', '!=');
$should_add_where_clause = TRUE;
}
if (!$account
->hasPermission('view community posts')) {
$and_condition
->condition('post__field_visibility.field_visibility_value', '2', '!=');
$should_add_where_clause = TRUE;
}
if ($should_add_where_clause) {
$this->query
->addWhere('visibility', $and_condition);
}
}
}
Classes
Name | Description |
---|---|
PostVisibilityAccess | Filters post based on visibility settings. |