You are here

DirectoryListBuilder.php in Private files download permission 3.x

Same filename and directory in other branches
  1. 8.2 src/DirectoryListBuilder.php

Namespace

Drupal\pfdp

File

src/DirectoryListBuilder.php
View source
<?php

namespace Drupal\pfdp;

use Drupal\Core\Config\Entity\ConfigEntityListBuilder;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Link;
use Drupal\Core\Site\Settings;
use Drupal\Core\Url;
use Drupal\user\Entity\Role;
use Drupal\user\Entity\User;

/**
 * Defines a class to build a list of Private files download permission
 * directory entities.
 */
class DirectoryListBuilder extends ConfigEntityListBuilder {

  /**
   * {@inheritdoc}
   */
  public function render() {
    $settings = \Drupal::config('pfdp.settings');

    // Prepare the information render array.
    $information = [];
    $information['margin'] = [
      '#markup' => '<p />',
    ];

    // Check if the file system download method is set to private.
    if ('private' !== \Drupal::config('system.file')
      ->get('default_scheme')) {
      \Drupal::messenger()
        ->addWarning($this
        ->t('Your @default_download_method is not set to private. Please keep in mind that these settings only affect private file system downloads.', [
        '@default_download_method' => Link::fromTextAndUrl('default download method', Url::fromRoute('system.file_system_settings'))
          ->toString(),
      ]));
    }

    // Check the private file system path.
    $private_file_system_path = Settings::get('file_private_path');
    if (!$private_file_system_path) {
      \Drupal::messenger()
        ->addWarning($this
        ->t('Your private file system path is not set.'));
    }
    else {
      $information['private_file_system_path'] = [
        '#markup' => '<p>' . $this
          ->t('Your private file system path is set to %path.', [
          '%path' => $private_file_system_path,
        ]) . '</p>',
      ];
    }

    // Check if by-user checks are enabled.
    if (!$settings
      ->get('by_user_checks')) {
      $information['by_user_checks'] = [
        '#markup' => '<p>' . $this
          ->t('@by_user_checks are not enabled.', [
          '@by_user_checks' => Link::fromTextAndUrl('By-user checks', Url::fromRoute('pfdp.settings'))
            ->toString(),
        ]) . '</p>',
      ];
    }

    // Return the render array.
    return $information + parent::render();
  }

  /**
   * {@inheritdoc}
   */
  public function buildHeader() {

    // Prepare the table header.
    $header = [];
    $header['id'] = $this
      ->t('Id');
    $header['path'] = $this
      ->t('Directory path');
    $header['bypass'] = $this
      ->t('Bypass');
    $header['users'] = $this
      ->t('Enabled users');
    $header['roles'] = $this
      ->t('Enabled roles');

    // Return the table header.
    return $header + parent::buildHeader();
  }

  /**
   * {@inheritdoc}
   */
  public function buildRow(EntityInterface $entity) {
    $pfdp_directory = $entity;

    // Prepare the table row for the directory.
    $row = [];
    $row['id'] = $pfdp_directory
      ->id();
    $row['path'] = $pfdp_directory->path;
    $row['bypass'] = $pfdp_directory->bypass ? $this
      ->t('Yes') : '';
    $row['users'] = implode(', ', array_map(function ($uid) {
      $user = User::load($uid);
      return $user ? $user
        ->label() : NULL;
    }, pfdp_get_proper_user_array($pfdp_directory->users)));
    if ($pfdp_directory->grant_file_owners) {
      $row['users'] = $this
        ->t('File owners') . ', ' . $row['users'];
    }
    if (', ' == mb_substr($row['users'], -2, 2)) {
      $row['users'] = mb_substr($row['users'], 0, -2);
    }
    $row['roles'] = implode(', ', array_map(function ($rid) {
      $role = Role::load($rid);
      return $role ? $role
        ->label() : NULL;
    }, $pfdp_directory->roles));
    if (', ' == mb_substr($row['roles'], -2, 2)) {
      $row['roles'] = mb_substr($row['roles'], 0, -2);
    }

    // Return the table row.
    return $row + parent::buildRow($pfdp_directory);
  }

  /**
   * {@inheritdoc}
   */
  public function getDefaultOperations(EntityInterface $entity) {
    $pfdp_directory = $entity;

    // Prepare the table row operations for the directory.
    $operations = parent::getDefaultOperations($pfdp_directory);
    if ($pfdp_directory
      ->hasLinkTemplate('edit')) {
      $operations['edit'] = [
        'title' => t('Edit directory'),
        'weight' => 20,
        'url' => $pfdp_directory
          ->toUrl('edit'),
      ];
    }
    if ($pfdp_directory
      ->hasLinkTemplate('delete')) {
      $operations['delete'] = [
        'title' => t('Delete directory'),
        'weight' => 40,
        'url' => $pfdp_directory
          ->toUrl('delete'),
      ];
    }

    // Return the table row operations.
    return $operations;
  }

}

Classes

Namesort descending Description
DirectoryListBuilder Defines a class to build a list of Private files download permission directory entities.