269 lines
8.7 KiB
PHP
Executable File
269 lines
8.7 KiB
PHP
Executable File
<?php
|
|
/*
|
|
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
|
|
* Copyright (C) DevCode s.n.c.
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
include_once __DIR__.'/../../core.php';
|
|
|
|
use Plugins\ImportFE\FatturaElettronica;
|
|
use Plugins\ImportFE\Interaction;
|
|
|
|
$file = null;
|
|
switch (filter('op')) {
|
|
case 'list':
|
|
$list = Interaction::getRemoteList();
|
|
|
|
echo json_encode($list);
|
|
|
|
break;
|
|
|
|
case 'save':
|
|
$temp_name = $_FILES['blob']['tmp_name'];
|
|
$name = $_FILES['blob']['name'];
|
|
|
|
if (ends_with($name, '.zip')) {
|
|
$directory = FatturaElettronica::getImportDirectory();
|
|
|
|
Util\Zip::extract($temp_name, $directory);
|
|
|
|
// Redirect forzato per l'importazione
|
|
echo json_encode([
|
|
'id' => 1,
|
|
]);
|
|
exit();
|
|
} else {
|
|
$content = file_get_contents($temp_name);
|
|
|
|
$file = FatturaElettronica::store($_FILES['blob']['name'], $content);
|
|
}
|
|
|
|
// no break
|
|
case 'prepare':
|
|
if (!isset($file)) {
|
|
$name = filter('name');
|
|
$file = Interaction::getInvoiceFile($name);
|
|
}
|
|
|
|
try {
|
|
if (!FatturaElettronica::isValid($file)) {
|
|
echo json_encode([
|
|
'already' => 1,
|
|
]);
|
|
|
|
return;
|
|
}
|
|
} catch (Exception $e) {
|
|
}
|
|
|
|
// Individuazione ID fisico
|
|
$files = Interaction::getFileList();
|
|
foreach ($files as $key => $value) {
|
|
if ($value['name'] == $file) {
|
|
$index = $key;
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
echo json_encode([
|
|
'id' => $index + 1,
|
|
]);
|
|
|
|
break;
|
|
|
|
case 'delete':
|
|
$file_id = get('file_id');
|
|
|
|
$directory = FatturaElettronica::getImportDirectory();
|
|
$files = Interaction::getFileList();
|
|
$file = $files[$file_id];
|
|
|
|
if (!empty($file)) {
|
|
delete($directory.'/'.$file['name']);
|
|
}
|
|
|
|
break;
|
|
|
|
case 'download':
|
|
$file_id = get('file_id');
|
|
|
|
$directory = FatturaElettronica::getImportDirectory();
|
|
$files = Interaction::getFileList();
|
|
$file = $files[$file_id];
|
|
|
|
if (!empty($file)) {
|
|
download($directory.'/'.$file['name']);
|
|
}
|
|
|
|
break;
|
|
|
|
case 'generate':
|
|
$filename = post('filename');
|
|
|
|
$info = [
|
|
'id_pagamento' => post('pagamento'),
|
|
'id_segment' => post('id_segment'),
|
|
'id_tipo' => post('id_tipo'),
|
|
'ref_fattura' => post('ref_fattura'),
|
|
'data_registrazione' => post('data_registrazione'),
|
|
'articoli' => post('articoli'),
|
|
'iva' => post('iva'),
|
|
'conto' => post('conto'),
|
|
'tipo_riga_riferimento' => post('tipo_riga_riferimento'),
|
|
'id_riga_riferimento' => post('id_riga_riferimento'),
|
|
'movimentazione' => post('movimentazione'),
|
|
'crea_articoli' => post('crea_articoli'),
|
|
];
|
|
|
|
$fattura_pa = FatturaElettronica::manage($filename);
|
|
$id_fattura = $fattura_pa->save($info);
|
|
|
|
ricalcola_costiagg_fattura($id_fattura);
|
|
elimina_scadenze($id_fattura);
|
|
elimina_movimenti($id_fattura, 0);
|
|
aggiungi_scadenza($id_fattura);
|
|
aggiungi_movimento($id_fattura, 'uscita');
|
|
|
|
$fattura_pa->delete();
|
|
|
|
//Aggiorno la tipologia di anagrafica fornitore
|
|
$anagrafica = $dbo->fetchOne('SELECT idanagrafica FROM co_documenti WHERE co_documenti.id='.prepare($id_fattura));
|
|
$rs_t = $dbo->fetchOne("SELECT * FROM an_tipianagrafiche_anagrafiche WHERE idtipoanagrafica=(SELECT an_tipianagrafiche.idtipoanagrafica FROM an_tipianagrafiche WHERE an_tipianagrafiche.descrizione='Fornitore') AND idanagrafica=".prepare($anagrafica['idanagrafica']));
|
|
|
|
//Se non trovo corrispondenza aggiungo all'anagrafica la tipologia fornitore
|
|
if (empty($rs_t)) {
|
|
$dbo->query("INSERT INTO an_tipianagrafiche_anagrafiche (idtipoanagrafica, idanagrafica) VALUES ((SELECT an_tipianagrafiche.idtipoanagrafica FROM an_tipianagrafiche WHERE an_tipianagrafiche.descrizione='Fornitore'), ".prepare($anagrafica['idanagrafica']).')');
|
|
}
|
|
|
|
// Processo il file ricevuto
|
|
if (Interaction::isEnabled()) {
|
|
$process_result = Interaction::processInvoice($filename);
|
|
if ($process_result != '') {
|
|
flash()->error($process_result);
|
|
redirect(ROOTDIR.'/controller.php?id_module='.$id_module);
|
|
|
|
return;
|
|
}
|
|
}
|
|
|
|
$files = Interaction::getFileList();
|
|
$file = $files[$id_record - 1];
|
|
|
|
if (get('sequence') == null) {
|
|
redirect(ROOTDIR.'/editor.php?id_module='.$id_module.'&id_record='.$id_fattura);
|
|
} elseif (!empty($file)) {
|
|
redirect(ROOTDIR.'/editor.php?id_module='.$id_module.'&id_plugin='.$id_plugin.'&id_record='.$id_record.'&sequence=1');
|
|
} else {
|
|
flash()->info(tr('Tutte le fatture salvate sono state importate!'));
|
|
redirect(ROOTDIR.'/controller.php?id_module='.$id_module);
|
|
}
|
|
break;
|
|
|
|
case 'process':
|
|
$name = get('name');
|
|
|
|
// Processo il file ricevuto
|
|
if (Interaction::isEnabled()) {
|
|
$process_result = Interaction::processInvoice($name);
|
|
if (!empty($process_result)) {
|
|
flash()->error($process_result);
|
|
}
|
|
}
|
|
|
|
break;
|
|
|
|
case 'compile':
|
|
if (empty($anagrafica)) {
|
|
echo json_encode([]);
|
|
|
|
return;
|
|
}
|
|
|
|
$fatture = $anagrafica->fattureAcquisto()
|
|
->contabile()
|
|
->orderByDesc('created_at')
|
|
->take(10)
|
|
->get();
|
|
|
|
$righe = collect();
|
|
foreach ($fatture as $fattura) {
|
|
$righe->push($fattura->righe);
|
|
$righe->push($fattura->articoli);
|
|
}
|
|
$righe = $righe->flatten();
|
|
|
|
// Ricerca del tipo di documento più utilizzato
|
|
$tipi = $fatture->groupBy(function ($item, $key) {
|
|
return $item->tipo->id;
|
|
})->transform(function ($item, $key) {
|
|
return $item->count();
|
|
});
|
|
$id_tipo = $tipi->sort()->keys()->last();
|
|
|
|
// Ricerca del tipo di pagamento più utilizzato
|
|
$pagamenti = $fatture->mapToGroups(function ($item, $key) {
|
|
return [$item->pagamento->id => $item->pagamento];
|
|
});
|
|
$id_pagamento = $pagamenti->map(function ($item, $key) {
|
|
return $item->count();
|
|
})->sort()->keys()->last();
|
|
$pagamento = $pagamenti[$id_pagamento]->first();
|
|
|
|
// Ricerca del conto più utilizzato
|
|
$conti = $righe->groupBy(function ($item, $key) {
|
|
return $item->idconto;
|
|
})->transform(function ($item, $key) {
|
|
return $item->count();
|
|
});
|
|
$id_conto = $conti->sort()->keys()->last();
|
|
$conto = $dbo->fetchOne('SELECT * FROM co_pianodeiconti3 WHERE id = '.prepare($id_conto));
|
|
|
|
// Ricerca dell'IVA più utilizzata secondo percentuali
|
|
$iva = [];
|
|
$percentuali_iva = $righe->groupBy(function ($item, $key) {
|
|
return $item->aliquota->percentuale;
|
|
});
|
|
foreach ($percentuali_iva as $key => $values) {
|
|
$aliquote = $values->mapToGroups(function ($item, $key) {
|
|
return [$item->aliquota->id => $item->aliquota];
|
|
});
|
|
$id_aliquota = $aliquote->map(function ($item, $key) {
|
|
return $item->count();
|
|
})->sort()->keys()->last();
|
|
$aliquota = $aliquote[$id_aliquota]->first();
|
|
|
|
$iva[$key] = [
|
|
'id' => $aliquota->id,
|
|
'descrizione' => $aliquota->descrizione,
|
|
];
|
|
}
|
|
|
|
echo json_encode([
|
|
'id_tipo' => $id_tipo,
|
|
'pagamento' => [
|
|
'id' => $pagamento->id,
|
|
'descrizione' => $pagamento->descrizione,
|
|
],
|
|
'conto' => [
|
|
'id' => $conto['id'],
|
|
'descrizione' => $conto['descrizione'],
|
|
],
|
|
'iva' => $iva,
|
|
]);
|
|
break;
|
|
}
|