Revisione sincronizzazione Flash da Applicazione

This commit is contained in:
Dasc3er 2021-09-14 15:54:03 +02:00
parent 23b31347e4
commit 9027bfad75
2 changed files with 119 additions and 40 deletions

View File

@ -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;
}
}

View File

@ -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)
{