From 9027bfad755cfec9ef7114c920d066e18961d82b Mon Sep 17 00:00:00 2001 From: Dasc3er Date: Tue, 14 Sep 2021 15:54:03 +0200 Subject: [PATCH] Revisione sincronizzazione Flash da Applicazione --- src/API/App/v1/Flash/Intervento.php | 157 +++++++++++++++++++++------- src/API/App/v1/Revisione.php | 2 +- 2 files changed, 119 insertions(+), 40 deletions(-) diff --git a/src/API/App/v1/Flash/Intervento.php b/src/API/App/v1/Flash/Intervento.php index a659b0460..c2cb964c7 100644 --- a/src/API/App/v1/Flash/Intervento.php +++ b/src/API/App/v1/Flash/Intervento.php @@ -30,10 +30,37 @@ use Carbon\Carbon; class Intervento extends Resource implements UpdateInterface { - public function update($request) + /** + * Elenco risorse API. + * + * @var array + */ + protected $risorse; + + /** + * Verifica sulla presenza di conflitti. + * + * @var bool + */ + protected $conflitti_rilevati = false; + + /** + * Record da considerare per l'importazione. + * + * @var array + */ + protected $records = []; + + /** + * Response delle richieste. + * + * @var array + */ + protected $response = []; + + public function __construct() { - // Elenco risorse API - $risorse = [ + $this->risorse = [ 'cliente' => new Clienti(), 'intervento' => new Interventi(), @@ -41,41 +68,22 @@ class Intervento extends Resource implements UpdateInterface 'sessioni' => new SessioniInterventi(), 'allegati' => new AllegatiInterventi(), ]; - $sezioni = array_keys($risorse); - - // Generazione record semplificati - $records = []; - foreach ($sezioni as $sezione) { - if (isset($request[$sezione][0])) { - foreach ($request[$sezione] as $record) { - $records[] = [$record, $risorse[$sezione]]; - } - } elseif (!empty($request[$sezione])) { - $records[] = [$request[$sezione], $risorse[$sezione]]; - } - } + } + public function update($request) + { // Controlli sui conflitti - $conflict = false; - foreach ($records as $key => [$record, $risorsa]) { - $ultima_modifica = new Carbon($record['updated_at']); - $ultima_sincronizzazione = new Carbon($record['last_sync_at']); - if (!empty($record['last_sync_at']) && !$ultima_modifica->greaterThan($ultima_sincronizzazione)) { - unset($records[$key]); - continue; + foreach ($request as $key => $record) { + $records = $record; + if (!isset($records[0])) { + $records = [$records]; } - $modifiche = $risorsa->getModifiedRecords($record['last_sync_at']); - $modifiche = array_keys($modifiche); - - if (in_array($record['id'], $modifiche)) { - $conflict = true; - break; - } + $this->processaRecords($key, $records); } // Messaggio di conflitto in caso di problematica riscontrata - if ($conflict) { + if ($this->conflitti_rilevati) { return [ 'status' => 200, 'message' => 'CONFLICT', @@ -83,16 +91,87 @@ class Intervento extends Resource implements UpdateInterface } // Salvataggio delle modifiche - foreach ($records as [$record, $risorsa]) { - if (!empty($record['deleted_at'])) { - $risorsa->deleteRecord($record['id']); - } elseif (!empty($record['remote_id'])) { - $risorsa->updateRecord($record); - } else { - $risorsa->createRecord($record); + foreach ($this->records as $key => $records) { + $this->importaRecords($key, $records); + } + + return $this->response; + } + + /** + * @param $key + * @param $records + */ + protected function processaRecords($key, $request) + { + $records = []; + + // Controlli sui conflitti + foreach ($request as $id => $record) { + $risorsa = $this->risorse[$key]; + if (empty($risorsa) || empty($record)) { + continue; + } + + $includi = $this->verificaConflitti($record, $risorsa); + if ($includi) { + $records[$id] = $record; } } - return []; + // Registrazione dei record individuati + if (!empty($records)) { + $this->records[$key] = $records; + } + } + + /** + * @param $key + * @param $records + */ + protected function importaRecords($key, $records) + { + $this->response[$key] = []; + $risorsa = $this->risorse[$key]; + + foreach ($records as $id => $record) { + // Fix id_cliente per Intervento in caso di generazione da zero + if ($risorsa instanceof Interventi && !empty($this->response['cliente'][$id])) { + $record['id_cliente'] = $this->response['cliente'][$id]['id']; + } + + $response = null; + if (!empty($record['deleted_at'])) { + $risorsa->deleteRecord($record['id']); + } elseif (!empty($record['remote_id'])) { + $response = $risorsa->updateRecord($record); + } else { + $response = $risorsa->createRecord($record); + } + + $this->response[$key][$id] = $response; + } + } + + /** + * @param $record + * @param $risorsa + * + * @return bool + */ + protected function verificaConflitti($record, $risorsa) + { + $ultima_modifica = new Carbon($record['updated_at']); + $ultima_sincronizzazione = new Carbon($record['last_sync_at']); + if (!empty($record['last_sync_at']) && !$ultima_modifica->greaterThan($ultima_sincronizzazione)) { + return false; + } + + $modifiche = $risorsa->getModifiedRecords($record['last_sync_at']); + $modifiche = array_keys($modifiche); + + $this->conflitti_rilevati |= in_array($record['id'], $modifiche); + + return true; } } diff --git a/src/API/App/v1/Revisione.php b/src/API/App/v1/Revisione.php index 860308c17..f9b4145bf 100644 --- a/src/API/App/v1/Revisione.php +++ b/src/API/App/v1/Revisione.php @@ -24,7 +24,7 @@ use API\Resource; class Revisione extends Resource implements RetrieveInterface { - const REVISION = '1.2'; + const REVISION = '1.3'; public function retrieve($request) {