mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-11 06:11:13 +01:00
159 lines
4.5 KiB
PHP
159 lines
4.5 KiB
PHP
<?php
|
||
|
||
|
||
class sfirm
|
||
{
|
||
/** @var Application $app */
|
||
var $app;
|
||
|
||
function __construct()
|
||
{
|
||
}
|
||
|
||
/**
|
||
* @param string $csv
|
||
* @param int $konto
|
||
* @param Application $app
|
||
*
|
||
* @return array
|
||
*/
|
||
function ImportKontoauszug($csv='',$konto=0,$app=null)
|
||
{
|
||
$this->app = $app;
|
||
$resultparse = $this->parse_csv($csv,';');
|
||
$dateCol = 1;
|
||
array_shift($resultparse); // remove header 1
|
||
if(!empty($resultparse[0][0]) && $resultparse[0][0]=== 'Buchung' && !empty($resultparse[1])) {
|
||
$bookingdate = $this->app->String->Convert($resultparse[1][0], '%1.%2.%3', '%3-%2-%1');
|
||
if($this->app->erp->CheckDateValidate($bookingdate)) {
|
||
$dateCol = 0;
|
||
}
|
||
}
|
||
array_shift($resultparse); // remove header 2
|
||
$duplicate = 0;
|
||
$newcsv="date;description;amount;currency\r\n";
|
||
$inserted = 0;
|
||
|
||
|
||
// fix values
|
||
$gebuehr = 0;
|
||
$gegenkonto = "";
|
||
$stamp = time();
|
||
|
||
$userName = $app->User->GetName();
|
||
$userName = $app->DB->real_escape_string($userName);
|
||
|
||
$cresultparse = count($resultparse);
|
||
//Buchung;Wertstellung;;Buchungstext;Beg<65>nstigter/Zahlungspflichtiger;;;Verwendungszweck;Betrag;W<>hrung;Auszugsnr.;Laufender Saldo;
|
||
for($row=0;$row<$cresultparse;$row++)
|
||
{
|
||
$bookingdate = $this->app->String->Convert($resultparse[$row][$dateCol], '%1.%2.%3', '%3-%2-%1'); // Wertstellung
|
||
$description = trim(preg_replace('/\s\s+/', ' ',$resultparse[$row][$dateCol]." ".$resultparse[$row][4]));
|
||
$has_h = stripos($resultparse[$row][8], 'H') !== false;
|
||
$has_s = stripos($resultparse[$row][8], 'S') !== false;
|
||
|
||
$resultparse[$row][8] = str_replace('H','',$resultparse[$row][8]);
|
||
$resultparse[$row][8] = str_replace('S','',$resultparse[$row][8]);
|
||
|
||
|
||
$amount = trim(str_replace(array('.', ','), array('', '.'), $resultparse[$row][8]));
|
||
|
||
$haben = 0;
|
||
$soll = 0;
|
||
|
||
if($has_s) {
|
||
$soll = $amount;
|
||
$amount = $amount * -1;
|
||
} else {
|
||
$haben = $amount;
|
||
}
|
||
|
||
|
||
$currency = $resultparse[$row][9];
|
||
if($amount <> 0 && $this->app->erp->CheckDateValidate($bookingdate) && $description!="")
|
||
{
|
||
$pruefsumme = md5(serialize(array($bookingdate, $description, $soll, $haben, $currency)));
|
||
|
||
$check = $app->DB->Select("SELECT id FROM kontoauszuege WHERE buchung='$bookingdate' AND konto='$konto' AND pruefsumme='$pruefsumme' LIMIT 1");
|
||
if($check > 0) {
|
||
$duplicate++;
|
||
continue;
|
||
}
|
||
|
||
$sql = "INSERT INTO kontoauszuege (
|
||
konto,
|
||
buchung,
|
||
vorgang,
|
||
soll,
|
||
haben,
|
||
gebuehr,
|
||
waehrung,
|
||
fertig,
|
||
bearbeiter,
|
||
pruefsumme,
|
||
importgroup,
|
||
originalbuchung,
|
||
originalvorgang,
|
||
originalsoll,
|
||
originalhaben,
|
||
originalgebuehr,
|
||
originalwaehrung,
|
||
gegenkonto
|
||
) VALUE (
|
||
'$konto',
|
||
'$bookingdate',
|
||
'$description',
|
||
'$soll',
|
||
'$haben',
|
||
'$gebuehr',
|
||
'$currency',
|
||
0,
|
||
'".$userName."',
|
||
'$pruefsumme',
|
||
'$stamp',
|
||
'$bookingdate',
|
||
'$description',
|
||
'$soll',
|
||
'$haben',
|
||
'$gebuehr',
|
||
'$currency',
|
||
'$gegenkonto')";
|
||
|
||
$app->DB->Insert($sql);
|
||
$newid = $app->DB->GetInsertID();
|
||
$app->DB->Update("UPDATE kontoauszuege SET sort='$newid' WHERE id='$newid' LIMIT 1");
|
||
$inserted++;
|
||
}
|
||
}
|
||
|
||
return array($inserted, $duplicate);
|
||
}
|
||
|
||
function parse_csv ($csv_string, $delimiter = ",", $skip_empty_lines = true, $trim_fields = true)
|
||
{
|
||
$enc = preg_replace('/(?<!")""/', '!!Q!!', $csv_string);
|
||
$enc = preg_replace_callback(
|
||
'/"(.*?)"/s',
|
||
function ($field) {
|
||
return urlencode(utf8_encode($field[1]));
|
||
},
|
||
$enc
|
||
);
|
||
$lines = preg_split($skip_empty_lines ? ($trim_fields ? '/( *\R)+/s' : '/\R+/s') : '/\R/s', $enc);
|
||
return array_map(
|
||
function ($line) use ($delimiter, $trim_fields) {
|
||
$fields = $trim_fields ? array_map('trim', explode($delimiter, $line)) : explode($delimiter, $line);
|
||
return array_map(
|
||
function ($field) {
|
||
return str_replace('!!Q!!', '"', utf8_decode(urldecode($field)));
|
||
},
|
||
$fields
|
||
);
|
||
},
|
||
$lines
|
||
);
|
||
}
|
||
|
||
}
|
||
|