mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-31 02:36:28 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			135 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * IngDescription.php
 | |
|  * Copyright (C) 2016 https://github.com/tomwerf.
 | |
|  *
 | |
|  * 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\Import\Specifics;
 | |
| 
 | |
| /**
 | |
|  * Class IngDescription.
 | |
|  *
 | |
|  * Parses the description from CSV files for Ing bank accounts.
 | |
|  *
 | |
|  * With Mutation 'InternetBankieren', 'Overschrijving', 'Verzamelbetaling' and
 | |
|  * 'Incasso' the Name of Opposing account the Opposing IBAN number are in the
 | |
|  * Description. This class will remove them, and add Name in description by
 | |
|  * 'Betaalautomaat' so those are easily recognizable
 | |
|  */
 | |
| class IngDescription implements SpecificInterface
 | |
| {
 | |
|     /** @var array */
 | |
|     public $row;
 | |
| 
 | |
|     /**
 | |
|      * @return string
 | |
|      */
 | |
|     public static function getDescription(): string
 | |
|     {
 | |
|         return 'Create better descriptions in ING import files.';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return string
 | |
|      */
 | |
|     public static function getName(): string
 | |
|     {
 | |
|         return 'ING description';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param array $row
 | |
|      *
 | |
|      * @return array
 | |
|      */
 | |
|     public function run(array $row): array
 | |
|     {
 | |
|         $this->row = array_values($row);
 | |
|         if (count($this->row) >= 8) {                    // check if the array is correct
 | |
|             switch ($this->row[4]) {                     // Get value for the mutation type
 | |
|                 case 'GT':                               // InternetBankieren
 | |
|                 case 'OV':                               // Overschrijving
 | |
|                 case 'VZ':                               // Verzamelbetaling
 | |
|                 case 'IC':                               // Incasso
 | |
|                     $this->removeIBANIngDescription();
 | |
|                     $this->removeNameIngDescription();
 | |
|                     // if "tegenrekening" empty, copy the description. Primitive, but it works.
 | |
|                     $this->copyDescriptionToOpposite();
 | |
|                     break;
 | |
|                 case 'BA':                              // Betaalautomaat
 | |
|                     $this->addNameIngDescription();
 | |
|                     break;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return $this->row;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add the Opposing name from cell 1 in the description for Betaalautomaten
 | |
|      * Otherwise the description is only: 'Pasvolgnr:<nr> <date> Transactie:<NR> Term:<nr>'.
 | |
|      *
 | |
|      * @return bool true
 | |
|      */
 | |
|     protected function addNameIngDescription()
 | |
|     {
 | |
|         $this->row[8] = $this->row[1] . ' ' . $this->row[8];
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Remove IBAN number out of the  description
 | |
|      * Default description of Description is: Naam: <OPPOS NAME> Omschrijving: <DESCRIPTION> IBAN: <OPPOS IBAN NR>.
 | |
|      *
 | |
|      * @return bool true
 | |
|      */
 | |
|     protected function removeIBANIngDescription()
 | |
|     {
 | |
|         // Try replace the iban number with nothing. The IBAN nr is found in the third row
 | |
|         $this->row[8] = preg_replace('/\sIBAN:\s' . $this->row[3] . '/', '', $this->row[8]);
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Remove name from the description (Remove everything before the description incl the word 'Omschrijving' ).
 | |
|      *
 | |
|      * @return bool true
 | |
|      */
 | |
|     protected function removeNameIngDescription()
 | |
|     {
 | |
|         // Try remove everything before the 'Omschrijving'
 | |
|         $this->row[8] = preg_replace('/.+Omschrijving: /', '', $this->row[8]);
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      *
 | |
|      */
 | |
|     private function copyDescriptionToOpposite(): void
 | |
|     {
 | |
|         $search = ['Naar Oranje Spaarrekening ', 'Afschrijvingen'];
 | |
|         if (strlen($this->row[3]) === 0) {
 | |
|             $this->row[3] = trim(str_ireplace($search, '', $this->row[8]));
 | |
|         }
 | |
|     }
 | |
| }
 |