mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-08 07:03:23 -06:00
Merge pull request #1797 from bnw/develop
Parse description from FinTSTransaction
This commit is contained in:
commit
21a8d9a109
37
app/Support/FinTS/MetadataParser.php
Normal file
37
app/Support/FinTS/MetadataParser.php
Normal file
@ -0,0 +1,37 @@
|
||||
<?php
|
||||
/**
|
||||
* FinTS.php
|
||||
* Copyright (c) 2018 https://github.com/bnw
|
||||
*
|
||||
* This file is part of Firefly III.
|
||||
*
|
||||
* Firefly III 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.
|
||||
*
|
||||
* Firefly III 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 Firefly III. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace FireflyIII\Support\FinTS;
|
||||
use Fhp\Model\StatementOfAccount\Transaction as FinTSTransaction;
|
||||
|
||||
class MetadataParser
|
||||
{
|
||||
function getDescription(FinTSTransaction $transaction)
|
||||
{
|
||||
//Given a description like 'EREF+AbcCRED+DE123SVWZ+DefABWA+Ghi' or 'EREF+AbcCRED+DE123SVWZ+Def' return 'Def'
|
||||
$finTSDescription = $transaction->getDescription1();
|
||||
if (preg_match('/SVWZ\+([^\+]*)([A-Z]{4}\+|$)/', $finTSDescription, $matches) === 1) {
|
||||
return $matches[1];
|
||||
}
|
||||
return $finTSDescription;
|
||||
}
|
||||
}
|
@ -34,6 +34,7 @@ use FireflyIII\Models\TransactionType;
|
||||
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
||||
use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface;
|
||||
use FireflyIII\Support\FinTS\FinTS;
|
||||
use FireflyIII\Support\FinTS\MetadataParser;
|
||||
use FireflyIII\Support\Import\Routine\File\OpposingAccountMapper;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
|
||||
@ -141,11 +142,14 @@ class StageImportDataHandler
|
||||
Log::debug('Both are assets, will make transfer.');
|
||||
}
|
||||
|
||||
$metadataParser = new MetadataParser();
|
||||
$description = $metadataParser->getDescription($transaction);
|
||||
|
||||
$storeData = [
|
||||
'user' => $this->importJob->user_id,
|
||||
'type' => $type,
|
||||
'date' => $transaction->getValutaDate()->format('Y-m-d'),
|
||||
'description' => $transaction->getDescription1(),
|
||||
'description' => $description,
|
||||
'piggy_bank_id' => null,
|
||||
'piggy_bank_name' => null,
|
||||
'bill_id' => null,
|
||||
|
71
tests/Unit/Support/FinTS/MetadataParserTest.php
Normal file
71
tests/Unit/Support/FinTS/MetadataParserTest.php
Normal file
@ -0,0 +1,71 @@
|
||||
<?php
|
||||
/**
|
||||
* FinTS.php
|
||||
* Copyright (c) 2018 https://github.com/bnw
|
||||
*
|
||||
* This file is part of Firefly III.
|
||||
*
|
||||
* Firefly III 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.
|
||||
*
|
||||
* Firefly III 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 Firefly III. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Tests\Unit\Support\FinTS;
|
||||
|
||||
use Fhp\Model\StatementOfAccount\Transaction as FinTSTransaction;
|
||||
|
||||
use FireflyIII\Support\FinTS\MetadataParser;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
use Tests\TestCase;
|
||||
|
||||
class MetadataParserTest extends TestCase
|
||||
{
|
||||
|
||||
/** @var MetadataParser */
|
||||
private $metadataParser;
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
public function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
Log::info(sprintf('Now in %s.', \get_class($this)));
|
||||
$this->metadataParser = new MetadataParser();
|
||||
}
|
||||
|
||||
public function testDescriptionIsCorrectlyExtractedFromBeginning()
|
||||
{
|
||||
$transaction = $this->createTransactionWithDescription1('SVWZ+DescriptionABWA+xxx');
|
||||
$this->assertEquals('Description', $this->metadataParser->getDescription($transaction));
|
||||
}
|
||||
|
||||
public function testDescriptionIsCorrectlyExtractedFromMiddle()
|
||||
{
|
||||
$transaction = $this->createTransactionWithDescription1('EREF+AbcCRED+DE123SVWZ+DescriptionABWA+Ghi');
|
||||
$this->assertEquals('Description', $this->metadataParser->getDescription($transaction));
|
||||
}
|
||||
|
||||
public function testDescriptionIsCorrectlyExtractedFromEnd()
|
||||
{
|
||||
$transaction = $this->createTransactionWithDescription1('EREF+AbcCRED+DE123SVWZ+Description');
|
||||
$this->assertEquals('Description', $this->metadataParser->getDescription($transaction));
|
||||
}
|
||||
|
||||
private function createTransactionWithDescription1(string $description1)
|
||||
{
|
||||
$transaction = $this->mock(FinTSTransaction::class);
|
||||
$transaction->shouldReceive('getDescription1')->atLeast()->once()->andReturn($description1);
|
||||
return $transaction;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user