OpenXE/classes/Modules/MandatoryFields/Service/MandatoryFieldsGateway.php

224 lines
5.2 KiB
PHP
Raw Permalink Normal View History

2021-05-21 08:49:41 +02:00
<?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;
}
}