firefly-iii/app/Helpers/Csv/Wizard.php

200 lines
4.6 KiB
PHP
Raw Normal View History

2015-07-04 23:18:02 -05:00
<?php
2016-02-05 05:08:25 -06:00
declare(strict_types = 1);
2015-07-04 23:18:02 -05:00
namespace FireflyIII\Helpers\Csv;
use Auth;
use Config;
use Crypt;
use FireflyIII\Exceptions\FireflyException;
use FireflyIII\Helpers\Csv\Mapper\MapperInterface;
2015-07-04 23:18:02 -05:00
use League\Csv\Reader;
2015-07-15 14:06:26 -05:00
use Log;
use ReflectionException;
2015-07-04 23:18:02 -05:00
use Session;
2016-02-23 09:15:37 -06:00
use SplFileObject;
use Storage;
2015-07-15 14:06:26 -05:00
2015-07-04 23:18:02 -05:00
/**
* Class Wizard
*
* @package FireflyIII\Helpers\Csv
*/
class Wizard implements WizardInterface
{
/**
* @param Reader $reader
* @param array $map
* @param bool $hasHeaders
*
* @return array
*/
2016-02-05 02:25:15 -06:00
public function getMappableValues(Reader $reader, array $map, bool $hasHeaders)
2015-07-04 23:18:02 -05:00
{
$values = [];
/*
* Loop over the CSV and collect mappable data:
*/
2015-07-07 03:05:11 -05:00
$keys = array_keys($map);
2015-07-04 23:18:02 -05:00
foreach ($reader as $index => $row) {
2015-07-07 03:05:11 -05:00
if ($this->useRow($hasHeaders, $index)) {
2015-07-04 23:18:02 -05:00
// collect all map values
2015-07-07 03:05:11 -05:00
foreach ($keys as $column) {
2015-07-04 23:18:02 -05:00
$values[$column][] = $row[$column];
}
}
}
/*
* Make each one unique.
*/
2015-07-08 06:05:33 -05:00
$values = $this->uniqueRecursive($values);
2015-07-04 23:18:02 -05:00
return $values;
}
/**
* @param array $roles
2016-02-05 02:25:15 -06:00
* @param array $map
2015-07-04 23:18:02 -05:00
*
* @return array
*/
2016-02-05 02:25:15 -06:00
public function processSelectedMapping(array $roles, array $map)
2015-07-04 23:18:02 -05:00
{
$configRoles = Config::get('csv.roles');
$maps = [];
if (is_array($map)) {
$keys = array_keys($map);
foreach ($keys as $index) {
2015-07-04 23:18:02 -05:00
if (isset($roles[$index])) {
$name = $roles[$index];
if ($configRoles[$name]['mappable']) {
$maps[$index] = $name;
}
}
}
}
return $maps;
}
/**
2016-02-05 02:25:15 -06:00
* @param array $input
2015-07-04 23:18:02 -05:00
*
* @return array
*/
2016-02-05 02:25:15 -06:00
public function processSelectedRoles(array $input)
2015-07-04 23:18:02 -05:00
{
$roles = [];
/*
* Store all rows for each column:
*/
if (is_array($input)) {
foreach ($input as $index => $role) {
if ($role != '_ignore') {
$roles[$index] = $role;
}
}
}
return $roles;
}
/**
* @param array $fields
*
* @return bool
*/
public function sessionHasValues(array $fields)
{
foreach ($fields as $field) {
if (!Session::has($field)) {
2015-07-09 08:20:55 -05:00
Log::error('Session is missing field: ' . $field);
2015-07-15 14:06:26 -05:00
2015-07-04 23:18:02 -05:00
return false;
}
}
return true;
}
/**
* @param array $map
*
* @return array
* @throws FireflyException
*/
public function showOptions(array $map)
{
2015-07-06 09:52:18 -05:00
$options = [];
2015-07-04 23:18:02 -05:00
foreach ($map as $index => $columnRole) {
$mapper = Config::get('csv.roles.' . $columnRole . '.mapper');
if (is_null($mapper)) {
throw new FireflyException('Cannot map field of type "' . $columnRole . '".');
2015-07-04 23:18:02 -05:00
}
$class = 'FireflyIII\Helpers\Csv\Mapper\\' . $mapper;
try {
/** @var MapperInterface $mapObject */
2015-07-07 12:09:45 -05:00
$mapObject = app($class);
} catch (ReflectionException $e) {
throw new FireflyException('Column "' . $columnRole . '" cannot be mapped because mapper class ' . $mapper . ' does not exist.');
}
$set = $mapObject->getMap();
2015-07-04 23:18:02 -05:00
$options[$index] = $set;
}
return $options;
}
/**
2016-02-05 02:25:15 -06:00
* @param string $path
2015-07-04 23:18:02 -05:00
*
* @return string
*/
2016-02-05 02:25:15 -06:00
public function storeCsvFile(string $path)
2015-07-04 23:18:02 -05:00
{
$time = str_replace(' ', '-', microtime());
$fileName = 'csv-upload-' . Auth::user()->id . '-' . $time . '.csv.encrypted';
2016-02-23 09:15:37 -06:00
$disk = Storage::disk('upload');
$file = new SplFileObject($path, 'r');
$content = $file->fread($file->getSize());
2015-07-04 23:18:02 -05:00
$contentEncrypted = Crypt::encrypt($content);
2016-02-23 09:15:37 -06:00
$disk->put($fileName, $contentEncrypted);
2015-07-04 23:18:02 -05:00
2016-02-23 09:15:37 -06:00
return $fileName;
2015-07-04 23:18:02 -05:00
}
2015-07-07 03:05:11 -05:00
2015-07-08 06:05:33 -05:00
/**
* @param array $array
*
* @return array
*/
protected function uniqueRecursive(array $array)
{
foreach ($array as $column => $found) {
$array[$column] = array_unique($found);
}
return $array;
}
2016-01-19 06:59:54 -06:00
/**
* @param bool $hasHeaders
* @param int $index
*
* @return bool
*/
2016-02-05 02:25:15 -06:00
protected function useRow(bool $hasHeaders, int $index)
2016-01-19 06:59:54 -06:00
{
return ($hasHeaders && $index > 1) || !$hasHeaders;
}
2015-07-09 14:26:40 -05:00
}