mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-26 00:06:34 -06:00
333 lines
6.5 KiB
PHP
333 lines
6.5 KiB
PHP
<?php
|
|
namespace FireflyIII\Helpers\Csv;
|
|
|
|
use Crypt;
|
|
use League\Csv\Reader;
|
|
use Session;
|
|
|
|
/**
|
|
* Class Data
|
|
*
|
|
* @package FireflyIII\Helpers\Csv
|
|
*/
|
|
class Data
|
|
{
|
|
|
|
/** @var string */
|
|
protected $csvFileContent;
|
|
|
|
/** @var string */
|
|
protected $delimiter;
|
|
|
|
/** @var string */
|
|
protected $csvFileLocation;
|
|
|
|
/** @var string */
|
|
protected $dateFormat;
|
|
|
|
/** @var bool */
|
|
protected $hasHeaders;
|
|
|
|
/** @var array */
|
|
protected $map = [];
|
|
|
|
/** @var array */
|
|
protected $mapped = [];
|
|
|
|
/** @var Reader */
|
|
protected $reader;
|
|
|
|
/** @var array */
|
|
protected $roles = [];
|
|
|
|
/** @var array */
|
|
protected $specifix = [];
|
|
|
|
/** @var int */
|
|
protected $importAccount = 0;
|
|
|
|
/**
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->sessionHasHeaders();
|
|
$this->sessionDateFormat();
|
|
$this->sessionCsvFileLocation();
|
|
$this->sessionMap();
|
|
$this->sessionRoles();
|
|
$this->sessionMapped();
|
|
$this->sessionSpecifix();
|
|
$this->sessionImportAccount();
|
|
$this->sessionDelimiter();
|
|
}
|
|
|
|
protected function sessionHasHeaders()
|
|
{
|
|
if (Session::has('csv-has-headers')) {
|
|
$this->hasHeaders = (bool) Session::get('csv-has-headers');
|
|
}
|
|
}
|
|
|
|
protected function sessionImportAccount()
|
|
{
|
|
if (Session::has('csv-import-account')) {
|
|
$this->importAccount = intval(Session::get('csv-import-account'));
|
|
}
|
|
}
|
|
|
|
protected function sessionDateFormat()
|
|
{
|
|
if (Session::has('csv-date-format')) {
|
|
$this->dateFormat = (string) Session::get('csv-date-format');
|
|
}
|
|
}
|
|
|
|
protected function sessionCsvFileLocation()
|
|
{
|
|
if (Session::has('csv-file')) {
|
|
$this->csvFileLocation = (string) Session::get('csv-file');
|
|
}
|
|
}
|
|
|
|
protected function sessionMap()
|
|
{
|
|
if (Session::has('csv-map')) {
|
|
$this->map = (array) Session::get('csv-map');
|
|
}
|
|
}
|
|
|
|
protected function sessionRoles()
|
|
{
|
|
if (Session::has('csv-roles')) {
|
|
$this->roles = (array) Session::get('csv-roles');
|
|
}
|
|
}
|
|
|
|
protected function sessionMapped()
|
|
{
|
|
if (Session::has('csv-mapped')) {
|
|
$this->mapped = (array) Session::get('csv-mapped');
|
|
}
|
|
}
|
|
|
|
protected function sessionSpecifix()
|
|
{
|
|
if (Session::has('csv-specifix')) {
|
|
$this->specifix = (array) Session::get('csv-specifix');
|
|
}
|
|
}
|
|
|
|
protected function sessionDelimiter()
|
|
{
|
|
if (Session::has('csv-delimiter')) {
|
|
$this->delimiter = Session::get('csv-delimiter');
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getDateFormat()
|
|
{
|
|
return $this->dateFormat;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param mixed $dateFormat
|
|
*/
|
|
public function setDateFormat($dateFormat)
|
|
{
|
|
Session::put('csv-date-format', $dateFormat);
|
|
$this->dateFormat = $dateFormat;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param int $importAccount
|
|
*/
|
|
public function setImportAccount($importAccount)
|
|
{
|
|
Session::put('csv-import-account', $importAccount);
|
|
$this->importAccount = $importAccount;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function hasHeaders()
|
|
{
|
|
return $this->hasHeaders;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param bool $hasHeaders
|
|
*/
|
|
public function setHasHeaders($hasHeaders)
|
|
{
|
|
Session::put('csv-has-headers', $hasHeaders);
|
|
$this->hasHeaders = $hasHeaders;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getMap()
|
|
{
|
|
return $this->map;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $map
|
|
*/
|
|
public function setMap(array $map)
|
|
{
|
|
Session::put('csv-map', $map);
|
|
$this->map = $map;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getMapped()
|
|
{
|
|
return $this->mapped;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $mapped
|
|
*/
|
|
public function setMapped(array $mapped)
|
|
{
|
|
Session::put('csv-mapped', $mapped);
|
|
$this->mapped = $mapped;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return Reader
|
|
*/
|
|
public function getReader()
|
|
{
|
|
if (strlen($this->csvFileContent) === 0) {
|
|
$this->loadCsvFile();
|
|
}
|
|
|
|
if (is_null($this->reader)) {
|
|
$this->reader = Reader::createFromString($this->getCsvFileContent());
|
|
$this->reader->setDelimiter($this->delimiter);
|
|
}
|
|
|
|
return $this->reader;
|
|
}
|
|
|
|
protected function loadCsvFile()
|
|
{
|
|
$file = $this->getCsvFileLocation();
|
|
$content = file_get_contents($file);
|
|
$contentDecrypted = Crypt::decrypt($content);
|
|
$this->setCsvFileContent($contentDecrypted);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getCsvFileLocation()
|
|
{
|
|
return $this->csvFileLocation;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $csvFileLocation
|
|
*/
|
|
public function setCsvFileLocation($csvFileLocation)
|
|
{
|
|
Session::put('csv-file', $csvFileLocation);
|
|
$this->csvFileLocation = $csvFileLocation;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getCsvFileContent()
|
|
{
|
|
return $this->csvFileContent;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $csvFileContent
|
|
*/
|
|
public function setCsvFileContent($csvFileContent)
|
|
{
|
|
$this->csvFileContent = $csvFileContent;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getRoles()
|
|
{
|
|
return $this->roles;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $roles
|
|
*/
|
|
public function setRoles(array $roles)
|
|
{
|
|
Session::put('csv-roles', $roles);
|
|
$this->roles = $roles;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getSpecifix()
|
|
{
|
|
return is_array($this->specifix) ? $this->specifix : [];
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $specifix
|
|
*/
|
|
public function setSpecifix($specifix)
|
|
{
|
|
Session::put('csv-specifix', $specifix);
|
|
$this->specifix = $specifix;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getDelimiter()
|
|
{
|
|
return $this->delimiter;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $delimiter
|
|
*/
|
|
public function setDelimiter($delimiter)
|
|
{
|
|
Session::put('csv-delimiter', $delimiter);
|
|
$this->delimiter = $delimiter;
|
|
}
|
|
}
|