Correzione della procedura di aggiornamento

Rimozione delle classi per l'aggiornamento alla versione 2.4.10, che causano problemi con l'aumentare delle modifiche alle dipendenze.
This commit is contained in:
Dasc3er 2020-10-17 10:41:10 +02:00
parent 5e169b3ca1
commit 54b954bd62
1 changed files with 79 additions and 21 deletions

View File

@ -1,24 +1,82 @@
<?php <?php
use Update\v2_4_10\Anagrafica; $database = database();
use Update\v2_4_10\Fattura;
error_reporting(E_ALL & ~E_WARNING & ~E_CORE_WARNING & ~E_NOTICE & ~E_USER_DEPRECATED & ~E_STRICT); error_reporting(E_ALL & ~E_WARNING & ~E_CORE_WARNING & ~E_NOTICE & ~E_USER_DEPRECATED & ~E_STRICT);
// Fix del calcolo del bollo // Fix del calcolo del bollo
$fatture = Fattura::all(); $fatture = $database->fetchArray('SELECT id, bollo FROM co_documenti');
foreach ($fatture as $fattura) { foreach ($fatture as $fattura) {
$fattura->manageRigaMarcaDaBollo(); $bollo = floatval($fattura['bollo']);
if ($bollo > 0) {
$fatture = $database->query(
'insert into `co_righe_documenti` (`iddocumento`, `order`, `descrizione`, `um`, `idiva`, `idconto`, `calcolo_ritenuta_acconto`, `idritenutaacconto`, `ritenuta_contributi`, `idrivalsainps`, `prezzo_unitario_acquisto`, `sconto_unitario`, `tipo_sconto`, `qta`, `data_inizio_periodo`, `data_fine_periodo`, `riferimento_amministrazione`, `tipo_cessione_prestazione`, `ritenutaacconto`, `rivalsainps`, `subtotale`, `sconto`, `iva`, `desc_iva`, `iva_indetraibile`, `created_at`) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', [
0 => 1,
1 => 0,
2 => 'Marca da bollo',
3 => null,
4 => '110',
5 => '99',
6 => null,
7 => null,
8 => false,
9 => null,
10 => 0,
11 => 0.0,
12 => 'PRC',
13 => 1.0,
14 => null,
15 => null,
16 => '',
17 => '',
18 => 0.0,
19 => 0.0,
20 => $bollo,
21 => 0.0,
22 => 0.0,
23 => 'Escluso art. 15',
24 => 0.0,
25 => '2020-10-17 10:00:00',
]);
$id_riga_bollo = $database->lastInsertedId();
$database->query('UPDATE co_documenti SET $id_riga_bollo = '.prepare($id_riga_bollo).' WHERE id = '.prepare($fattura['id']));
}
} }
// Fix per le relazioni tariffe-tecnici // Fix per le relazioni tariffe-tecnici
$tecnici = Anagrafica::fromTipo('Tecnico')->get(); $tecnici = $database->fetchArray("SELECT DISTINCT(an_anagrafiche.idanagrafica) AS id FROM an_anagrafiche
INNER JOIN an_tipianagrafiche ON an_anagrafiche.idanagrafica = an_anagrafiche.idanagrafica
INNER JOIN an_tipianagrafiche_anagrafiche ON an_tipianagrafiche.idtipoanagrafica = an_tipianagrafiche_anagrafiche.idtipoanagrafica
WHERE an_tipianagrafiche.descrizione = 'Tecnico'");
foreach ($tecnici as $tecnico) { foreach ($tecnici as $tecnico) {
Anagrafica::fixTecnico($tecnico); $presenti = $database->fetchArray('SELECT idtipointervento AS id FROM in_tariffe WHERE idtecnico = '.prepare($tecnico['id']));
// Aggiunta associazioni costi unitari al contratto
$query = 'SELECT * FROM in_tipiintervento';
$elenco_presenti = array_column($presenti, 'id');
if (!empty($elenco_presenti)) {
$query .= ' WHERE idtipointervento NOT IN ('.implode(', ', $elenco_presenti).')';
}
$tipi = $database->fetchArray($query);
foreach ($tipi as $tipo) {
$database->insert('in_tariffe', [
'idtecnico' => $tecnico['id'],
'idtipointervento' => $tipo['id'],
'costo_ore' => $tipo['costo_orario'],
'costo_km' => $tipo['costo_km'],
'costo_dirittochiamata' => $tipo['costo_diritto_chiamata'],
'costo_ore_tecnico' => $tipo['costo_orario_tecnico'],
'costo_km_tecnico' => $tipo['costo_km_tecnico'],
'costo_dirittochiamata_tecnico' => $tipo['costo_diritto_chiamata_tecnico'],
]);
}
} }
// Spostamento automezzi su sedi // Spostamento automezzi su sedi
$automezzi = $dbo->fetchArray('SELECT * FROM dt_automezzi'); $automezzi = $database->fetchArray('SELECT * FROM dt_automezzi');
foreach ($automezzi as $automezzo) { foreach ($automezzi as $automezzo) {
$nomesede = []; $nomesede = [];
@ -26,7 +84,7 @@ foreach ($automezzi as $automezzo) {
(!empty($automezzo['descrizione'])) ? $nomesede[] = $automezzo['descrizione'] : null; (!empty($automezzo['descrizione'])) ? $nomesede[] = $automezzo['descrizione'] : null;
(!empty($automezzo['targa'])) ? $nomesede[] = $automezzo['targa'] : null; (!empty($automezzo['targa'])) ? $nomesede[] = $automezzo['targa'] : null;
$dbo->insert( $database->insert(
'an_sedi', 'an_sedi',
[ [
'nomesede' => implode(' - ', $nomesede), 'nomesede' => implode(' - ', $nomesede),
@ -34,10 +92,10 @@ foreach ($automezzi as $automezzo) {
] ]
); );
$idsede = $dbo->lastInsertedId(); $idsede = $database->lastInsertedId();
// Aggiornamento sede di partenza su // Aggiornamento sede di partenza su
$dbo->update( $database->update(
'in_interventi', 'in_interventi',
[ [
'idsede_partenza' => $idsede, 'idsede_partenza' => $idsede,
@ -48,23 +106,23 @@ foreach ($automezzi as $automezzo) {
} }
// Aggiornamento della sede azienda nei movimenti degli interventi // Aggiornamento della sede azienda nei movimenti degli interventi
$dbo->query('UPDATE mg_movimenti SET idsede_azienda=(SELECT idsede_partenza FROM in_interventi WHERE in_interventi.id=mg_movimenti.idintervento) WHERE idintervento IS NOT NULL'); $database->query('UPDATE mg_movimenti SET idsede_azienda=(SELECT idsede_partenza FROM in_interventi WHERE in_interventi.id=mg_movimenti.idintervento) WHERE idintervento IS NOT NULL');
// Cancellazione idautomezzo da mg_movimenti e in_interventi // Cancellazione idautomezzo da mg_movimenti e in_interventi
$dbo->query('ALTER TABLE in_interventi DROP idautomezzo'); $database->query('ALTER TABLE in_interventi DROP idautomezzo');
$dbo->query('ALTER TABLE mg_movimenti DROP idautomezzo'); $database->query('ALTER TABLE mg_movimenti DROP idautomezzo');
$dbo->query('ALTER TABLE co_promemoria_articoli DROP idautomezzo'); $database->query('ALTER TABLE co_promemoria_articoli DROP idautomezzo');
$dbo->query('ALTER TABLE co_righe_documenti DROP idautomezzo'); $database->query('ALTER TABLE co_righe_documenti DROP idautomezzo');
$dbo->query('ALTER TABLE mg_articoli_interventi DROP idautomezzo'); $database->query('ALTER TABLE mg_articoli_interventi DROP idautomezzo');
// Eliminazione tabelle degli automezzi non più usate // Eliminazione tabelle degli automezzi non più usate
$dbo->query('DROP TABLE mg_articoli_automezzi'); $database->query('DROP TABLE mg_articoli_automezzi');
$dbo->query('DROP TABLE dt_automezzi'); $database->query('DROP TABLE dt_automezzi');
$dbo->query('DROP TABLE dt_automezzi_tecnici'); $database->query('DROP TABLE dt_automezzi_tecnici');
$dbo->query('DELETE FROM zz_modules WHERE name="Automezzi"'); $database->query('DELETE FROM zz_modules WHERE name="Automezzi"');
//Rimuovo il codice come indice per in_interventi //Rimuovo il codice come indice per in_interventi
$dbo->query('ALTER TABLE `in_interventi` DROP INDEX `codice`'); $database->query('ALTER TABLE `in_interventi` DROP INDEX `codice`');
// File e cartelle deprecate // File e cartelle deprecate
$files = [ $files = [