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
<?php
/* --------------------------------------------------------------
InvoiceArchiveReadService.inc.php 24.04.16
Gambio GmbH
http://www.gambio.de
Copyright (c) 2016 Gambio GmbH
Released under the GNU General Public License (Version 2)
[http://www.gnu.org/licenses/gpl-2.0.html]
--------------------------------------------------------------
*/
/**
* Class InvoiceListArchiveReadService
*
* @category System
* @package Invoice
*/
class InvoiceArchiveReadService implements InvoiceArchiveReadServiceInterface
{
/**
* @var InvoiceListGeneratorInterface
*/
protected $listGenerator;
/**
* @var InvoiceFileFinderInterface
*/
protected $fileFinder;
/**
* InvoiceListArchiveReadService constructor.
*
* @param \InvoiceListGeneratorInterface $listGenerator
* @param \InvoiceFileFinderInterface $fileFinder
*/
public function __construct(InvoiceListGeneratorInterface $listGenerator, InvoiceFileFinderInterface $fileFinder)
{
$this->listGenerator = $listGenerator;
$this->fileFinder = $fileFinder;
}
/**
* Returns an invoice list item collection by the given conditions.
* The other arguments helps to control fetched data.
*
* @param array $conditions (Optional) Conditions for tht where clause.
* @param \IntType|null $startIndex (Optional) Start index for the limit clause.
* @param \IntType|null $maxCount (Optional) Max count for the limit clause.
* @param \StringType|null $orderBy (Optional) Sort order of fetched data.
*
* @return InvoiceListItemCollection
*/
public function getInvoiceListByConditions(array $conditions = [],
IntType $startIndex = null,
IntType $maxCount = null,
StringType $orderBy = null)
{
return $this->listGenerator->getInvoiceListByConditions($conditions, $startIndex, $maxCount, $orderBy);
}
/**
* Returns the invoice file download information.
*
* @param \IdType $invoiceId invoice_id of expected entry.
*
* @return FileDownloadInformation
*/
public function getInvoiceFileDownloadInfoByInvoiceId(IdType $invoiceId)
{
$filePath = $this->fileFinder->getFilenameByInvoiceId($invoiceId);
$filenameArray = explode('/', $filePath);
$filename = $filenameArray[count($filenameArray) - 1];
$preparedFileName = preg_replace('/_[a-z0-9]{32}/', '', $filename);
return MainFactory::create('FileDownloadInformation',
MainFactory::create('ExistingFile', new NonEmptyStringType($filePath)),
new FilenameStringType($preparedFileName));
}
}