mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-21 10:31:13 +01:00
224 lines
5.2 KiB
PHP
224 lines
5.2 KiB
PHP
|
<?php
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
namespace Xentral\Modules\MandatoryFields\Service;
|
||
|
|
||
|
use Xentral\Components\Database\Database;
|
||
|
use Xentral\Modules\MandatoryFields\Data\MandatoryFieldData;
|
||
|
use Xentral\Modules\MandatoryFields\Exception\MandatoryFieldNotFoundException;
|
||
|
|
||
|
final class MandatoryFieldsGateway
|
||
|
{
|
||
|
/** @var Database $db */
|
||
|
private $db;
|
||
|
|
||
|
/**
|
||
|
* @param Database $db
|
||
|
*/
|
||
|
public function __construct(Database $db)
|
||
|
{
|
||
|
$this->db = $db;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $module
|
||
|
* @param string $action
|
||
|
* @param string $fieldId
|
||
|
* @param string $type
|
||
|
*
|
||
|
* @return MandatoryFieldData|null
|
||
|
*/
|
||
|
public function getMandatoryFieldByParameters(
|
||
|
string $module,
|
||
|
string $action,
|
||
|
string $fieldId,
|
||
|
string $type
|
||
|
): ?MandatoryFieldData {
|
||
|
$sql =
|
||
|
'SELECT
|
||
|
`id`,
|
||
|
`module`,
|
||
|
`action`,
|
||
|
`field_id`,
|
||
|
`error_message`,
|
||
|
`type`,
|
||
|
`min_length`,
|
||
|
`max_length`,
|
||
|
`mandatory`,
|
||
|
`comparator`,
|
||
|
`compareto`
|
||
|
FROM `mandatory_field` AS `m`
|
||
|
WHERE m.module = :module
|
||
|
AND m.action = :action
|
||
|
AND m.type = :type
|
||
|
AND m.field_id = :field_id
|
||
|
LIMIT 1';
|
||
|
|
||
|
$values = [
|
||
|
'module' => $module,
|
||
|
'action' => $action,
|
||
|
'field_id' => $fieldId,
|
||
|
'type' => $type,
|
||
|
];
|
||
|
|
||
|
$data = $this->db->fetchRow($sql, $values);
|
||
|
|
||
|
if (!empty($data)) {
|
||
|
return MandatoryFieldData::fromDbState($data);
|
||
|
}
|
||
|
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $mandatoryFieldId
|
||
|
*
|
||
|
* @throws MandatoryFieldNotFoundException
|
||
|
*
|
||
|
* @return MandatoryFieldData
|
||
|
*/
|
||
|
public function getById(int $mandatoryFieldId): MandatoryFieldData
|
||
|
{
|
||
|
$sql =
|
||
|
'SELECT
|
||
|
`id`,
|
||
|
`module`,
|
||
|
`action`,
|
||
|
`field_id`,
|
||
|
`error_message`,
|
||
|
`type`,
|
||
|
`min_length`,
|
||
|
`max_length`,
|
||
|
`mandatory`,
|
||
|
`comparator`,
|
||
|
`compareto`
|
||
|
FROM `mandatory_field` AS `m`
|
||
|
WHERE m.id = :id
|
||
|
LIMIT 1';
|
||
|
|
||
|
$values = [
|
||
|
'id' => $mandatoryFieldId,
|
||
|
];
|
||
|
|
||
|
$data = $this->db->fetchRow($sql, $values);
|
||
|
|
||
|
if (empty($data)) {
|
||
|
throw new MandatoryFieldNotFoundException('No mandatory field record with the id:' . $mandatoryFieldId);
|
||
|
}
|
||
|
|
||
|
return MandatoryFieldData::fromDbState($data);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $customernumber
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function isAddressWithCustomerNumberActive(string $customerNumber): bool
|
||
|
{
|
||
|
$sql =
|
||
|
'SELECT a.id
|
||
|
FROM `adresse` AS `a`
|
||
|
WHERE a.kundennummer = :customer_number
|
||
|
AND a.kundennummer != \'\'
|
||
|
AND a.geloescht != 1';
|
||
|
|
||
|
$data = $this->db->fetchRow($sql, ['customer_number' => $customerNumber]);
|
||
|
|
||
|
if (empty($data)) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $employeeNumber
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function isAddressWithEmployeeNumberActive(string $employeeNumber): bool
|
||
|
{
|
||
|
$sql =
|
||
|
'SELECT a.id
|
||
|
FROM `adresse` AS `a`
|
||
|
WHERE a.mitarbeiternummer = :employee_number
|
||
|
AND a.mitarbeiternummer != \'\'
|
||
|
AND a.geloescht != 1';
|
||
|
|
||
|
$data = $this->db->fetchRow($sql, ['employee_number' => $employeeNumber]);
|
||
|
|
||
|
if (empty($data)) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $articleNumber
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function isArticleWithNumberActive(string $articleNumber): bool
|
||
|
{
|
||
|
$sql =
|
||
|
'SELECT a.id
|
||
|
FROM `artikel` AS `a`
|
||
|
WHERE a.nummer = :article_number
|
||
|
AND a.nummer != \'\'
|
||
|
AND a.geloescht != 1 ';
|
||
|
|
||
|
$data = $this->db->fetchRow($sql, ['article_number' => $articleNumber]);
|
||
|
|
||
|
if (empty($data)) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $documentNumber
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function isOrderWithDocumentNumberActive(string $documentNumber): bool
|
||
|
{
|
||
|
$sql =
|
||
|
'SELECT a.id
|
||
|
FROM `auftrag` AS `a`
|
||
|
WHERE a.belegnr = :document_number';
|
||
|
|
||
|
$data = $this->db->fetchRow($sql, ['document_number' => $documentNumber]);
|
||
|
|
||
|
if (empty($data)) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $documentNumber
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function isInvoiceWithDocumentNumberActive(string $documentNumber): bool
|
||
|
{
|
||
|
$sql =
|
||
|
'SELECT r.id
|
||
|
FROM `rechnung` AS `r`
|
||
|
WHERE r.belegnr = :document_number';
|
||
|
|
||
|
$data = $this->db->fetchRow($sql, ['document_number' => $documentNumber]);
|
||
|
|
||
|
if (empty($data)) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
}
|