OpenXE/classes/Modules/Api/Resource/TrackingNumberResource.php
2021-05-21 08:49:41 +02:00

189 lines
5.8 KiB
PHP

<?php
namespace Xentral\Modules\Api\Resource;
use Aura\SqlQuery\Exception;
use Xentral\Components\Database\SqlQuery\InsertQuery;
use Xentral\Components\Database\SqlQuery\SelectQuery;
use Xentral\Components\Database\SqlQuery\UpdateQuery;
use Xentral\Modules\Api\Controller\Version1\TrackingNumberController;
/**
* Ressource für Trackingnummern
*/
class TrackingNumberResource extends AbstractResource
{
/** @var string TABLE_NAME */
const TABLE_NAME = 'versand';
/**
* @return void
*/
protected function configure()
{
$this->setTableName(self::TABLE_NAME);
$this->registerFilterParams([
'tracking' => 'v.tracking %LIKE%',
'tracking_equals' => 'v.tracking LIKE',
'tracking_startswith' => 'v.tracking LIKE%',
'tracking_endswith' => 'v.tracking %LIKE',
'lieferschein' => 'l.belegnr %LIKE%',
'lieferschein_equals' => 'l.belegnr LIKE',
'lieferschein_startswith' => 'l.belegnr LIKE%',
'lieferschein_endswith' => 'l.belegnr %LIKE',
'auftrag' => 'au.belegnr %LIKE%',
'auftrag_equals' => 'au.belegnr LIKE',
'auftrag_startswith' => 'au.belegnr LIKE%',
'auftrag_endswith' => 'au.belegnr %LIKE',
'internet' => 'au.internet %LIKE%',
'internet_equals' => 'au.internet LIKE',
'internet_startswith' => 'au.internet LIKE%',
'internet_endswith' => 'au.internet %LIKE',
'versandart' => 'l.versandart LIKE',
'versendet_am' => 'v.versendet_am LIKE',
'versendet_am_gt' => 'v.versendet_am >',
'versendet_am_gte' => 'v.versendet_am >=',
'versendet_am_lt' => 'v.versendet_am <',
'versendet_am_lte' => 'v.versendet_am <=',
'abgeschlossen' => 'v.abgeschlossen =',
'adresse' => 'v.adresse =',
'projekt' => 'v.projekt =',
'land' => 'l.land =',
]);
$this->registerSortingParams([
'tracking' => 'v.tracking',
'auftrag' => 'au.belegnr',
'lieferschein' => 'l.belegnr',
'versandart' => 'l.versandart',
'versendet_am' => 'v.versendet_am',
'abgeschlossen' => 'v.abgeschlossen',
]);
/** Minimale Validation-Rules; die eigentliche Prüfung findet im Controller statt */
/** @see TrackingNumberController */
$this->registerValidationRules([
'tracking' => 'required',
]);
$this->registerIncludes([
'projekt' => [
'key' => 'projekt',
'resource' => ProjectResource::class,
'columns' => [
'p.id',
'p.name',
'p.abkuerzung',
'p.beschreibung',
'p.farbe',
],
],
]);
}
/**
* @throws Exception
*
* @return SelectQuery
*/
protected function selectAllQuery()
{
return $this->db->select()
->cols([
'v.id',
'v.tracking',
'v.adresse',
//'v.auftrag',
'au.internet',
'au.belegnr AS auftrag',
//'v.lieferschein',
'l.belegnr AS lieferschein',
//'v.rechnung',
//'r.belegnr AS rechnung',
'v.projekt',
//'v.versandart',
'l.versandart',
'l.land',
'v.gewicht',
//'v.freigegeben',
//'v.bearbeiter',
//'v.versender',
'v.abgeschlossen',
'v.versendet_am',
//'v.versandunternehmen',
//'v.download',
//'v.firma',
//'v.logdatei',
//'v.keinetrackingmail',
//'v.versendet_am_zeitstempel',
//'v.weitererlieferschein',
'v.anzahlpakete',
//'v.gelesen',
//'v.paketmarkegedruckt',
//'v.papieregedruckt',
//'v.versandzweigeteilt',
//'v.improzess',
//'v.improzessuser',
//'v.cronjob',
//'v.adressvalidation',
'v.retoure',
//'v.bundesstaat',
'v.klaergrund',
])
->from(self::TABLE_NAME . ' AS v')
->leftJoin('lieferschein AS l', 'v.lieferschein = l.id')
->leftJoin('auftrag AS au', 'l.auftragid = au.id');
}
/**
* @throws Exception
*
* @return SelectQuery
*/
protected function selectOneQuery()
{
return $this->selectAllQuery()->where('v.id = :id');
}
/**
* @return false
*/
protected function selectIdsQuery()
{
return false;
}
/**
* Insert-Action hat speziellen Controller
*
* @see TrackingNumberController::createAction()
*
* @return InsertQuery
*/
protected function insertQuery()
{
return $this->db->insert()->into(self::TABLE_NAME);
}
/**
* Update-Action hat speziellen Controller
*
* @see TrackingNumberController::updateAction()
*
* @return UpdateQuery
*/
protected function updateQuery()
{
return $this->db->update()->table(self::TABLE_NAME)->where('id = :id');
}
/**
* @return false
*/
protected function deleteQuery()
{
return false;
}
}