mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-15 08:11:14 +01:00
101 lines
3.1 KiB
PHP
101 lines
3.1 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Xentral\Modules\FiskalyApi\Factory;
|
|
|
|
use Aura\SqlQuery\Exception;
|
|
use Xentral\Components\Database\Database;
|
|
use Xentral\Modules\FiskalyApi\Data\Transaction\TransactionRequest;
|
|
|
|
class FiskalyTransactionFactory
|
|
{
|
|
/** @var Database $database */
|
|
private $database;
|
|
|
|
/**
|
|
* FiskalyTransactionFactory constructor.
|
|
*
|
|
* @param Database $db
|
|
*/
|
|
public function __construct(Database $db)
|
|
{
|
|
$this->database = $db;
|
|
}
|
|
|
|
/**
|
|
* @param int $projectId
|
|
*
|
|
* @throws Exception
|
|
* @return array
|
|
*/
|
|
public function getClientAndTssInfoFromProjectId(int $projectId): array
|
|
{
|
|
$posProjectQuery = $this->database->select()
|
|
->from('pos_kassierer AS p')
|
|
->cols(['f.tss_uuid', 'f.client_uuid', 'f.organization_id'])
|
|
->where('p.projekt=:project_id')
|
|
->leftJoin('fiskaly_pos_mapping AS f', 'f.pos_id = p.projekt')
|
|
->bindValue('project_id', $projectId);
|
|
return $this->database->fetchRow($posProjectQuery->getStatement(), $posProjectQuery->getBindValues());
|
|
}
|
|
|
|
/**
|
|
* @param string $cashierId
|
|
*
|
|
* @throws Exception
|
|
* @return array
|
|
*/
|
|
public function getClientAndTssInfoFromCashierId(string $cashierId): array
|
|
{
|
|
$posProjectQuery = $this->database->select()
|
|
->from('pos_kassierer AS p')
|
|
->cols(['f.tss_uuid', 'f.client_uuid', 'f.organization_id'])
|
|
->where('p.kassenkennung=:kennung')
|
|
->innerJoin('fiskaly_pos_mapping AS f', 'f.pos_id = p.projekt')
|
|
->bindValue('kennung', $cashierId);
|
|
return $this->database->fetchRow($posProjectQuery->getStatement(), $posProjectQuery->getBindValues());
|
|
}
|
|
|
|
/**
|
|
* @param string $tssId
|
|
*
|
|
* @throws Exception
|
|
* @return array
|
|
*/
|
|
public function getTssFromTssId(string $tssId): array
|
|
{
|
|
$posProjectQuery = $this->database->select()
|
|
->from('pos_kassierer AS p')
|
|
->cols(['f.tss_uuid', 'f.client_uuid', 'f.organization_id'])
|
|
->where('f.tss_uuid=:tss_uuid')
|
|
->innerJoin('fiskaly_pos_mapping AS f', 'f.pos_id = p.projekt')
|
|
->bindValue('tss_uuid', $tssId);
|
|
return $this->database->fetchRow($posProjectQuery->getStatement(), $posProjectQuery->getBindValues());
|
|
}
|
|
|
|
/**
|
|
* @param string $cashierId
|
|
*
|
|
* @throws Exception
|
|
* @return TransactionRequest
|
|
*/
|
|
public function getTransactionRequestFromPosSession(string $cashierId): TransactionRequest
|
|
{
|
|
$result = $this->getClientAndTssInfoFromCashierId($cashierId);
|
|
return (new TransactionRequest('ACTIVE', $result['client_uuid']))->setTssId($result['tss_uuid']);
|
|
}
|
|
|
|
/**
|
|
* @param int $projectId
|
|
*
|
|
* @throws Exception
|
|
* @return TransactionRequest
|
|
*/
|
|
public function getTransactionRequestFromProjectId(int $projectId): TransactionRequest
|
|
{
|
|
$result = $this->getClientAndTssInfoFromProjectId($projectId);
|
|
return (new TransactionRequest('ACTIVE', $result['client_uuid']))->setTssId($result['tss_uuid']);
|
|
}
|
|
}
|