|
|
@ -7,6 +7,7 @@ use Drupal\Core\Config\ConfigFactoryInterface; |
|
|
|
use Drupal\Core\Entity\EntityInterface; |
|
|
|
use Drupal\Core\Entity\EntityInterface; |
|
|
|
use Drupal\Core\Entity\EntityTypeManagerInterface; |
|
|
|
use Drupal\Core\Entity\EntityTypeManagerInterface; |
|
|
|
use Drupal\Core\Link; |
|
|
|
use Drupal\Core\Link; |
|
|
|
|
|
|
|
use Drupal\Core\Mail\MailManagerInterface; |
|
|
|
use Drupal\Core\StringTranslation\StringTranslationTrait; |
|
|
|
use Drupal\Core\StringTranslation\StringTranslationTrait; |
|
|
|
use Drupal\Core\StringTranslation\TranslationInterface; |
|
|
|
use Drupal\Core\StringTranslation\TranslationInterface; |
|
|
|
use Drupal\dgi_fixity\Entity\FixityCheck; |
|
|
|
use Drupal\dgi_fixity\Entity\FixityCheck; |
|
|
@ -47,10 +48,17 @@ class FixityCheckService implements FixityCheckServiceInterface { |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
protected $time; |
|
|
|
protected $time; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
|
|
* The mail manager service. |
|
|
|
|
|
|
|
* |
|
|
|
|
|
|
|
* @var \Drupal\Core\Mail\MailManagerInterface |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
protected $mailManager; |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* The logger for this service. |
|
|
|
* The logger for this service. |
|
|
|
* |
|
|
|
* |
|
|
|
* @var \Psr\Log\LoggerInterface |
|
|
|
* @var Psr\Log\LoggerInterface |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
protected $logger; |
|
|
|
protected $logger; |
|
|
|
|
|
|
|
|
|
|
@ -64,18 +72,12 @@ class FixityCheckService implements FixityCheckServiceInterface { |
|
|
|
/** |
|
|
|
/** |
|
|
|
* Constructor. |
|
|
|
* Constructor. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public function __construct( |
|
|
|
public function __construct(TranslationInterface $string_translation, ConfigFactoryInterface $config, EntityTypeManagerInterface $entity_type_manager, TimeInterface $time, MailManagerInterface $mail_manager, LoggerInterface $logger, FileHash $filehash) { |
|
|
|
TranslationInterface $string_translation, |
|
|
|
|
|
|
|
ConfigFactoryInterface $config, |
|
|
|
|
|
|
|
EntityTypeManagerInterface $entity_type_manager, |
|
|
|
|
|
|
|
TimeInterface $time, |
|
|
|
|
|
|
|
LoggerInterface $logger, |
|
|
|
|
|
|
|
FileHash $filehash, |
|
|
|
|
|
|
|
) { |
|
|
|
|
|
|
|
$this->stringTranslation = $string_translation; |
|
|
|
$this->stringTranslation = $string_translation; |
|
|
|
$this->config = $config; |
|
|
|
$this->config = $config; |
|
|
|
$this->entityTypeManager = $entity_type_manager; |
|
|
|
$this->entityTypeManager = $entity_type_manager; |
|
|
|
$this->time = $time; |
|
|
|
$this->time = $time; |
|
|
|
|
|
|
|
$this->mailManager = $mail_manager; |
|
|
|
$this->logger = $logger; |
|
|
|
$this->logger = $logger; |
|
|
|
$this->filehash = $filehash; |
|
|
|
$this->filehash = $filehash; |
|
|
|
} |
|
|
|
} |
|
|
@ -84,7 +86,10 @@ class FixityCheckService implements FixityCheckServiceInterface { |
|
|
|
* {@inheritdoc} |
|
|
|
* {@inheritdoc} |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public function fromEntityTypes(): array { |
|
|
|
public function fromEntityTypes(): array { |
|
|
|
return static::ENTITY_TYPES; |
|
|
|
return [ |
|
|
|
|
|
|
|
'media', |
|
|
|
|
|
|
|
'file', |
|
|
|
|
|
|
|
]; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
@ -218,7 +223,7 @@ class FixityCheckService implements FixityCheckServiceInterface { |
|
|
|
// Assume success until proven untrue. |
|
|
|
// Assume success until proven untrue. |
|
|
|
$state = FixityCheck::STATE_MATCHES; |
|
|
|
$state = FixityCheck::STATE_MATCHES; |
|
|
|
// If column is set, only generate that hash. |
|
|
|
// If column is set, only generate that hash. |
|
|
|
foreach ($this->filehash->getEnabledAlgorithms() as $column => $algo) { |
|
|
|
foreach ($this->filehash->algos() as $column => $algo) { |
|
|
|
// Nothing to do if the previous checksum value is not known. |
|
|
|
// Nothing to do if the previous checksum value is not known. |
|
|
|
if (!isset($file->{$column})) { |
|
|
|
if (!isset($file->{$column})) { |
|
|
|
$state = FixityCheck::STATE_NO_CHECKSUM; |
|
|
|
$state = FixityCheck::STATE_NO_CHECKSUM; |
|
|
|