mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2024-11-16 13:07:14 +01:00
382 lines
13 KiB
PHP
382 lines
13 KiB
PHP
<?php
|
|
|
|
namespace Xentral\Modules\Api\Resource;
|
|
|
|
use Xentral\Components\Database\SqlQuery\SelectQuery;
|
|
|
|
class AddressResource extends AbstractResource
|
|
{
|
|
const TABLE_NAME = 'adresse';
|
|
|
|
protected function configure()
|
|
{
|
|
$this->setTableName(self::TABLE_NAME);
|
|
|
|
$this->registerFilterParams([
|
|
'rolle' => 'ar.rolle %LIKE%',
|
|
'projekt' => 'a.projekt =',
|
|
'firma' => 'a.firma =',
|
|
'typ' => 'a.typ LIKE',
|
|
'sprache' => 'a.sprache LIKE',
|
|
'waehrung' => 'a.waehrung LIKE',
|
|
'land' => 'a.land LIKE',
|
|
'name' => 'a.name %LIKE%',
|
|
'name_equals' => 'a.name LIKE',
|
|
'name_startswith' => 'a.name LIKE%',
|
|
'name_endswith' => 'a.name %LIKE',
|
|
'kundennummer' => 'a.kundennummer %LIKE%',
|
|
'kundennummer_equals' => 'a.kundennummer LIKE',
|
|
'kundennummer_startswith' => 'a.kundennummer LIKE%',
|
|
'kundennummer_endswith' => 'a.kundennummer %LIKE',
|
|
'lieferantennummer' => 'a.lieferantennummer %LIKE%',
|
|
'lieferantennummer_equals' => 'a.lieferantennummer LIKE',
|
|
'lieferantennummer_startswith' => 'a.lieferantennummer LIKE%',
|
|
'lieferantennummer_endswith' => 'a.lieferantennummer %LIKE',
|
|
'mitarbeiternummer' => 'a.mitarbeiternummer %LIKE%',
|
|
'mitarbeiternummer_equals' => 'a.mitarbeiternummer LIKE',
|
|
'mitarbeiternummer_startswith' => 'a.mitarbeiternummer LIKE%',
|
|
'mitarbeiternummer_endswith' => 'a.mitarbeiternummer %LIKE',
|
|
'email' => 'a.email %LIKE%',
|
|
'email_equals' => 'a.email LIKE',
|
|
'email_startswith' => 'a.email LIKE%',
|
|
'email_endswith' => 'a.email %LIKE',
|
|
'freifeld1' => 'a.freifeld1 %LIKE%',
|
|
'freifeld2' => 'a.freifeld2 %LIKE%',
|
|
'freifeld3' => 'a.freifeld3 %LIKE%',
|
|
'freifeld4' => 'a.freifeld4 %LIKE%',
|
|
'freifeld5' => 'a.freifeld5 %LIKE%',
|
|
'freifeld6' => 'a.freifeld6 %LIKE%',
|
|
'freifeld7' => 'a.freifeld7 %LIKE%',
|
|
'freifeld8' => 'a.freifeld8 %LIKE%',
|
|
'freifeld9' => 'a.freifeld9 %LIKE%',
|
|
'freifeld10' => 'a.freifeld10 %LIKE%',
|
|
'freifeld1_equals' => 'a.freifeld1 LIKE',
|
|
'freifeld2_equals' => 'a.freifeld2 LIKE',
|
|
'freifeld3_equals' => 'a.freifeld3 LIKE',
|
|
'freifeld4_equals' => 'a.freifeld4 LIKE',
|
|
'freifeld5_equals' => 'a.freifeld5 LIKE',
|
|
'freifeld6_equals' => 'a.freifeld6 LIKE',
|
|
'freifeld7_equals' => 'a.freifeld7 LIKE',
|
|
'freifeld8_equals' => 'a.freifeld8 LIKE',
|
|
'freifeld9_equals' => 'a.freifeld9 LIKE',
|
|
'freifeld10_equals' => 'a.freifeld10 LIKE',
|
|
]);
|
|
|
|
$this->registerSortingParams([
|
|
'name' => 'a.name',
|
|
'kundennummer' => 'a.kundennummer',
|
|
'lieferantennummer' => 'a.lieferantennummer',
|
|
'mitarbeiternummer' => 'a.mitarbeiternummer',
|
|
]);
|
|
|
|
/*$this->registerValidationRules([
|
|
'id' => 'not_present',
|
|
'bezeichnung' => 'required',
|
|
'type' => 'required',
|
|
'projekt' => 'numeric',
|
|
'netto' => 'boolean',
|
|
'aktiv' => 'boolean',
|
|
]);*/
|
|
|
|
/*$this->registerIncludes([
|
|
'projekt' => [
|
|
'key' => 'projekt',
|
|
'resource' => ProjectResource::class,
|
|
'columns' => [
|
|
'p.id',
|
|
'p.name',
|
|
'p.abkuerzung',
|
|
'p.beschreibung',
|
|
'p.farbe',
|
|
],
|
|
],
|
|
]);*/
|
|
}
|
|
|
|
/**
|
|
* @return SelectQuery
|
|
*/
|
|
protected function selectAllQuery()
|
|
{
|
|
return $this->db->select()
|
|
->cols([
|
|
'a.id',
|
|
'ar.rolle',
|
|
'a.typ',
|
|
'a.marketingsperre',
|
|
'a.trackingsperre',
|
|
'a.rechnungsadresse',
|
|
'a.sprache',
|
|
'a.name',
|
|
'a.abteilung',
|
|
'a.unterabteilung',
|
|
'a.ansprechpartner',
|
|
'a.land',
|
|
'a.strasse',
|
|
'a.ort',
|
|
'a.plz',
|
|
'a.telefon',
|
|
'a.telefax',
|
|
'a.mobil',
|
|
'a.email',
|
|
'a.ustid',
|
|
'a.ust_befreit',
|
|
'a.passwort_gesendet',
|
|
'a.sonstiges',
|
|
'a.adresszusatz',
|
|
'a.kundenfreigabe',
|
|
'a.steuer',
|
|
'a.logdatei',
|
|
'a.kundennummer',
|
|
'a.lieferantennummer',
|
|
'a.mitarbeiternummer',
|
|
'a.konto',
|
|
'a.blz',
|
|
'a.bank',
|
|
'a.inhaber',
|
|
'a.swift',
|
|
'a.iban',
|
|
'a.waehrung',
|
|
'a.paypal',
|
|
'a.paypalinhaber',
|
|
'a.paypalwaehrung',
|
|
'a.projekt',
|
|
'a.partner',
|
|
'a.zahlungsweise',
|
|
'a.zahlungszieltage',
|
|
'a.zahlungszieltageskonto',
|
|
'a.zahlungszielskonto',
|
|
'a.versandart',
|
|
'a.kundennummerlieferant',
|
|
'a.zahlungsweiselieferant',
|
|
'a.zahlungszieltagelieferant',
|
|
'a.zahlungszieltageskontolieferant',
|
|
'a.zahlungszielskontolieferant',
|
|
'a.versandartlieferant',
|
|
'a.geloescht',
|
|
'a.firma',
|
|
'a.webid',
|
|
'a.vorname',
|
|
'a.kennung',
|
|
'a.sachkonto',
|
|
'a.filiale',
|
|
'a.vertrieb',
|
|
'a.innendienst',
|
|
'a.verbandsnummer',
|
|
'a.abweichendeemailab',
|
|
'a.portofrei_aktiv',
|
|
'a.portofreiab',
|
|
'a.infoauftragserfassung',
|
|
'a.mandatsreferenz',
|
|
'a.mandatsreferenzdatum',
|
|
'a.mandatsreferenzaenderung',
|
|
'a.glaeubigeridentnr',
|
|
'a.kreditlimit',
|
|
'a.tour',
|
|
'a.zahlungskonditionen_festschreiben',
|
|
'a.rabatte_festschreiben',
|
|
'a.mlmaktiv',
|
|
'a.mlmvertragsbeginn',
|
|
'a.mlmlizenzgebuehrbis',
|
|
'a.mlmfestsetzenbis',
|
|
'a.mlmfestsetzen',
|
|
'a.mlmmindestpunkte',
|
|
'a.mlmwartekonto',
|
|
'a.abweichende_rechnungsadresse',
|
|
'a.rechnung_vorname',
|
|
'a.rechnung_name',
|
|
'a.rechnung_titel',
|
|
'a.rechnung_typ',
|
|
'a.rechnung_strasse',
|
|
'a.rechnung_ort',
|
|
'a.rechnung_plz',
|
|
'a.rechnung_ansprechpartner',
|
|
'a.rechnung_land',
|
|
'a.rechnung_abteilung',
|
|
'a.rechnung_unterabteilung',
|
|
'a.rechnung_adresszusatz',
|
|
'a.rechnung_telefon',
|
|
'a.rechnung_telefax',
|
|
'a.rechnung_anschreiben',
|
|
'a.rechnung_email',
|
|
'a.geburtstag',
|
|
'a.rolledatum',
|
|
'a.liefersperre',
|
|
'a.liefersperregrund',
|
|
'a.mlmpositionierung',
|
|
'a.steuernummer',
|
|
'a.steuerbefreit',
|
|
'a.mlmmitmwst',
|
|
'a.mlmabrechnung',
|
|
'a.mlmwaehrungauszahlung',
|
|
'a.mlmauszahlungprojekt',
|
|
'a.sponsor',
|
|
'a.geworbenvon',
|
|
'a.logfile',
|
|
'a.kalender_aufgaben',
|
|
'a.verrechnungskontoreisekosten',
|
|
'a.usereditid',
|
|
'a.useredittimestamp',
|
|
'a.rabatt',
|
|
'a.provision',
|
|
'a.rabattinformation',
|
|
'a.rabatt1',
|
|
'a.rabatt2',
|
|
'a.rabatt3',
|
|
'a.rabatt4',
|
|
'a.rabatt5',
|
|
'a.internetseite',
|
|
'a.bonus1',
|
|
'a.bonus1_ab',
|
|
'a.bonus2',
|
|
'a.bonus2_ab',
|
|
'a.bonus3',
|
|
'a.bonus3_ab',
|
|
'a.bonus4',
|
|
'a.bonus4_ab',
|
|
'a.bonus5',
|
|
'a.bonus5_ab',
|
|
'a.bonus6',
|
|
'a.bonus6_ab',
|
|
'a.bonus7',
|
|
'a.bonus7_ab',
|
|
'a.bonus8',
|
|
'a.bonus8_ab',
|
|
'a.bonus9',
|
|
'a.bonus9_ab',
|
|
'a.bonus10',
|
|
'a.bonus10_ab',
|
|
'a.rechnung_periode',
|
|
'a.rechnung_anzahlpapier',
|
|
'a.rechnung_permail',
|
|
'a.titel',
|
|
'a.anschreiben',
|
|
'a.nachname',
|
|
'a.arbeitszeitprowoche',
|
|
'a.folgebestaetigungsperre',
|
|
'a.lieferantennummerbeikunde',
|
|
'a.verein_mitglied_seit',
|
|
'a.verein_mitglied_bis',
|
|
'a.verein_mitglied_aktiv',
|
|
'a.verein_spendenbescheinigung',
|
|
'a.freifeld1',
|
|
'a.freifeld2',
|
|
'a.freifeld3',
|
|
'a.freifeld4',
|
|
'a.freifeld5',
|
|
'a.freifeld6',
|
|
'a.freifeld7',
|
|
'a.freifeld8',
|
|
'a.freifeld9',
|
|
'a.freifeld10',
|
|
'a.rechnung_papier',
|
|
'a.angebot_cc',
|
|
'a.auftrag_cc',
|
|
'a.rechnung_cc',
|
|
'a.gutschrift_cc',
|
|
'a.lieferschein_cc',
|
|
'a.bestellung_cc',
|
|
'a.angebot_fax_cc',
|
|
'a.auftrag_fax_cc',
|
|
'a.rechnung_fax_cc',
|
|
'a.gutschrift_fax_cc',
|
|
'a.lieferschein_fax_cc',
|
|
'a.bestellung_fax_cc',
|
|
'a.abperfax',
|
|
'a.abpermail',
|
|
'a.kassiereraktiv',
|
|
'a.kassierernummer',
|
|
'a.kassiererprojekt',
|
|
'a.portofreilieferant_aktiv',
|
|
'a.portofreiablieferant',
|
|
'a.mandatsreferenzart',
|
|
'a.mandatsreferenzwdhart',
|
|
'a.serienbrief',
|
|
'a.kundennummer_buchhaltung',
|
|
'a.lieferantennummer_buchhaltung',
|
|
'a.lead',
|
|
'a.zahlungsweiseabo',
|
|
'a.bundesland',
|
|
'a.mandatsreferenzhinweis',
|
|
'a.geburtstagkalender',
|
|
'a.geburtstagskarte',
|
|
'a.liefersperredatum',
|
|
'a.umsatzsteuer_lieferant',
|
|
'a.lat',
|
|
'a.lng',
|
|
'a.art',
|
|
'a.angebot_email',
|
|
'a.auftrag_email',
|
|
'a.rechnungs_email',
|
|
'a.gutschrift_email',
|
|
'a.lieferschein_email',
|
|
'a.bestellung_email',
|
|
'a.firmensepa',
|
|
'a.anzeigesteuerbelege',
|
|
'a.gln',
|
|
'a.rechnung_gln',
|
|
'a.keinealtersabfrage',
|
|
'a.lieferbedingung',
|
|
'a.mlmintranetgesamtestruktur',
|
|
'a.kommissionskonsignationslager',
|
|
'a.zollinformationen',
|
|
'a.bundesstaat',
|
|
'a.rechnung_bundesstaat',
|
|
'a.lieferschwellenichtanwenden',
|
|
])
|
|
->from(self::TABLE_NAME . ' AS a')
|
|
->joinSubSelect(
|
|
'LEFT',
|
|
'SELECT ar.adresse, GROUP_CONCAT(LOWER(ar.subjekt)) AS rolle ' .
|
|
'FROM adresse_rolle AS ar ' .
|
|
'WHERE (ar.bis = \'0000-00-00\' OR ar.bis >= CURDATE())' .
|
|
'AND (ar.von = \'0000-00-00\' OR ar.von <= CURDATE())' .
|
|
'AND (ar.subjekt = \'Kunde\' OR ar.subjekt = \'Lieferant\') ' .
|
|
'GROUP BY ar.adresse ',
|
|
'ar',
|
|
'a.id = ar.adresse'
|
|
)
|
|
->where('a.geloescht <> 1');
|
|
}
|
|
|
|
/**
|
|
* @return SelectQuery
|
|
*/
|
|
protected function selectOneQuery()
|
|
{
|
|
return $this->selectAllQuery()->where('a.id = :id');
|
|
}
|
|
|
|
/**
|
|
* @return SelectQuery
|
|
*/
|
|
protected function selectIdsQuery()
|
|
{
|
|
return $this->selectAllQuery()->where('a.id IN (:ids)');
|
|
}
|
|
|
|
/**
|
|
* @return false
|
|
*/
|
|
protected function insertQuery()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* @return false
|
|
*/
|
|
protected function updateQuery()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* @return false
|
|
*/
|
|
protected function deleteQuery()
|
|
{
|
|
return false;
|
|
}
|
|
}
|