Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php
declare(strict_types=1);
/*
* This file is part of the "gsb_metadata_cleaner" Extension for TYPO3 CMS.
*
* For the full copyright and license information, please read the
* LICENSE file that was distributed with this source code.
*/
namespace ITZBund\GsbMetadataCleaner\Configuration;
use Psr\Log\LoggerInterface;
use Psr\Log\LogLevel;
use TYPO3\CMS\Core\Configuration\Exception\ExtensionConfigurationExtensionNotConfiguredException;
use TYPO3\CMS\Core\Configuration\Exception\ExtensionConfigurationPathDoesNotExistException;
use TYPO3\CMS\Core\Configuration\ExtensionConfiguration as CoreExtensionConfiguration;
class ExtensionConfiguration
{
protected string $defaultExifToolPath = '/usr/bin/exiftool';
protected string $defaultQpdfToolPath = '/usr/bin/qpdf';
public function __construct(
private readonly CoreExtensionConfiguration $extensionConfiguration,
private readonly LoggerInterface $logger
) {}
/**
* Get the path to the exiftool executable, defined by extension configuration or default
*
* @return string the path to the exiftool executable
*/
public function getExifToolPath(): string
{
$exifToolPath = '';
try {
$exifToolPath = $this->extensionConfiguration->get('gsb_metadata_cleaner', 'exifToolPath');
} catch (ExtensionConfigurationExtensionNotConfiguredException $ecence) {
$this->logger->log(LogLevel::DEBUG, 'Extension not configured');
} catch (ExtensionConfigurationPathDoesNotExistException $ecpdnee) {
$this->logger->log(LogLevel::DEBUG, 'exifToolPath not configured');
}
if (trim((string)$exifToolPath) !== '') {
if (file_exists($exifToolPath)) {
return trim((string)$exifToolPath);
}
$this->logger->log(LogLevel::ERROR, 'exifToolPath configured, but not found', [
'exifToolPath' => trim((string)$exifToolPath),
]);
}
return $this->defaultExifToolPath;
}
/**
* Get the path to the qpdf executable, defined by extension configuration or default
*
* @return string the path to the pdf executable
*/
public function getQpdfToolPath(): string
{
$qpdfToolPath = '';
try {
$qpdfToolPath = $this->extensionConfiguration->get('gsb_metadata_cleaner', 'qpdfToolPath');
} catch (ExtensionConfigurationExtensionNotConfiguredException $ecence) {
$this->logger->log(LogLevel::DEBUG, 'Extension not configured');
} catch (ExtensionConfigurationPathDoesNotExistException $ecpdnee) {
$this->logger->log(LogLevel::DEBUG, 'qpdfToolPath not configured');
}
if (trim((string)$qpdfToolPath) !== '') {
if (file_exists($qpdfToolPath)) {
return trim((string)$qpdfToolPath);
}
$this->logger->log(LogLevel::ERROR, 'qpdfToolPath configured, but not found', [
'qpdfToolPath' => trim((string)$qpdfToolPath),
]);
}
return $this->defaultQpdfToolPath;
}
public function getUseQpdf(): bool
{
$useQpdf = true;
try {
$useQpdf = (bool)$this->extensionConfiguration->get('gsb_metadata_cleaner', 'useQpdf');
} catch (ExtensionConfigurationExtensionNotConfiguredException $ecence) {
$this->logger->log(LogLevel::DEBUG, 'Extension not configured');
} catch (ExtensionConfigurationPathDoesNotExistException $ecpdnee) {
$this->logger->log(LogLevel::DEBUG, 'useQpdf not configured');
}
return $useQpdf;
}
}