$row) { if ($this->useRow($hasHeaders, $index)) { // collect all map values foreach ($keys as $column) { $values[$column][] = $row[$column]; } } } /* * Make each one unique. */ $values = $this->uniqueRecursive($values); return $values; } /** * @param array $roles * @param array $map * * @return array */ public function processSelectedMapping(array $roles, array $map) { $configRoles = Config::get('csv.roles'); $maps = []; if (is_array($map)) { $keys = array_keys($map); foreach ($keys as $index) { if (isset($roles[$index])) { $name = $roles[$index]; if ($configRoles[$name]['mappable']) { $maps[$index] = $name; } } } } return $maps; } /** * @param array $input * * @return array */ public function processSelectedRoles(array $input) { $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)) { Log::error('Session is missing field: ' . $field); return false; } } return true; } /** * @param array $map * * @return array * @throws FireflyException */ public function showOptions(array $map) { $options = []; 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 . '".'); } $class = 'FireflyIII\Helpers\Csv\Mapper\\' . $mapper; try { /** @var MapperInterface $mapObject */ $mapObject = app($class); } catch (ReflectionException $e) { throw new FireflyException('Column "' . $columnRole . '" cannot be mapped because class ' . $mapper . ' does not exist.'); } $set = $mapObject->getMap(); $options[$index] = $set; } return $options; } /** * @param string $path * * @return string */ public function storeCsvFile(string $path) { $time = str_replace(' ', '-', microtime()); $fileName = 'csv-upload-' . Auth::user()->id . '-' . $time . '.csv.encrypted'; $fullPath = storage_path('upload') . DIRECTORY_SEPARATOR . $fileName; $content = file_get_contents($path); $contentEncrypted = Crypt::encrypt($content); file_put_contents($fullPath, $contentEncrypted); return $fullPath; } /** * @param array $array * * @return array */ protected function uniqueRecursive(array $array) { foreach ($array as $column => $found) { $array[$column] = array_unique($found); } return $array; } /** * @param bool $hasHeaders * @param int $index * * @return bool */ protected function useRow(bool $hasHeaders, int $index) { return ($hasHeaders && $index > 1) || !$hasHeaders; } }