mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-24 11:51:12 +01:00
189 lines
5.8 KiB
PHP
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;
|
|
}
|
|
}
|