mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-26 16:26:35 -06:00
151 lines
4.3 KiB
PHP
151 lines
4.3 KiB
PHP
<?php
|
|
/**
|
|
* AttachmentCollector.php
|
|
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
|
*
|
|
* This software may be modified and distributed under the terms of the
|
|
* Creative Commons Attribution-ShareAlike 4.0 International License.
|
|
*
|
|
* See the LICENSE file for details.
|
|
*/
|
|
|
|
declare(strict_types = 1);
|
|
|
|
namespace FireflyIII\Export\Collector;
|
|
|
|
use Amount;
|
|
use Crypt;
|
|
use FireflyIII\Models\Attachment;
|
|
use FireflyIII\Models\ExportJob;
|
|
use FireflyIII\Models\TransactionJournal;
|
|
use FireflyIII\Repositories\Attachment\AttachmentRepositoryInterface;
|
|
use Illuminate\Contracts\Encryption\DecryptException;
|
|
use Illuminate\Support\Collection;
|
|
use Log;
|
|
use Storage;
|
|
|
|
/**
|
|
* Class AttachmentCollector
|
|
*
|
|
* @package FireflyIII\Export\Collector
|
|
*/
|
|
class AttachmentCollector extends BasicCollector implements CollectorInterface
|
|
{
|
|
/** @var string */
|
|
private $explanationString = '';
|
|
/** @var \Illuminate\Contracts\Filesystem\Filesystem */
|
|
private $exportDisk;
|
|
/** @var AttachmentRepositoryInterface */
|
|
private $repository;
|
|
/** @var \Illuminate\Contracts\Filesystem\Filesystem */
|
|
private $uploadDisk;
|
|
|
|
/**
|
|
* AttachmentCollector constructor.
|
|
*
|
|
* @param ExportJob $job
|
|
*/
|
|
public function __construct(ExportJob $job)
|
|
{
|
|
/** @var AttachmentRepositoryInterface repository */
|
|
$this->repository = app(AttachmentRepositoryInterface::class);
|
|
// make storage:
|
|
$this->uploadDisk = Storage::disk('upload');
|
|
$this->exportDisk = Storage::disk('export');
|
|
|
|
parent::__construct($job);
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
public function run(): bool
|
|
{
|
|
// grab all the users attachments:
|
|
$attachments = $this->getAttachments();
|
|
|
|
/** @var Attachment $attachment */
|
|
foreach ($attachments as $attachment) {
|
|
$this->exportAttachment($attachment);
|
|
}
|
|
|
|
// put the explanation string in a file and attach it as well.
|
|
$file = $this->job->key . '-Source of all your attachments explained.txt';
|
|
$this->exportDisk->put($file, $this->explanationString);
|
|
$this->getFiles()->push($file);
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* @param Attachment $attachment
|
|
*/
|
|
private function explain(Attachment $attachment)
|
|
{
|
|
/** @var TransactionJournal $journal */
|
|
$journal = $attachment->attachable;
|
|
$args = [
|
|
'attachment_name' => e($attachment->filename),
|
|
'attachment_id' => $attachment->id,
|
|
'type' => strtolower($journal->transactionType->type),
|
|
'description' => e($journal->description),
|
|
'journal_id' => $journal->id,
|
|
'date' => $journal->date->formatLocalized(strval(trans('config.month_and_day'))),
|
|
'amount' => Amount::formatJournal($journal, false),
|
|
];
|
|
$string = trans('firefly.attachment_explanation', $args) . "\n";
|
|
Log::debug('Appended explanation string', ['string' => $string]);
|
|
$this->explanationString .= $string;
|
|
|
|
}
|
|
|
|
/**
|
|
* @param Attachment $attachment
|
|
*
|
|
* @return bool
|
|
*/
|
|
private function exportAttachment(Attachment $attachment): bool
|
|
{
|
|
$file = $attachment->fileName();
|
|
if ($this->uploadDisk->exists($file)) {
|
|
try {
|
|
$decrypted = Crypt::decrypt($this->uploadDisk->get($file));
|
|
$exportFile = $this->exportFileName($attachment);
|
|
$this->exportDisk->put($exportFile, $decrypted);
|
|
$this->getFiles()->push($exportFile);
|
|
|
|
// explain:
|
|
$this->explain($attachment);
|
|
} catch (DecryptException $e) {
|
|
Log::error('Catchable error: could not decrypt attachment #' . $attachment->id . ' because: ' . $e->getMessage());
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the new file name for the export file.
|
|
*
|
|
* @param $attachment
|
|
*
|
|
* @return string
|
|
*/
|
|
private function exportFileName($attachment): string
|
|
{
|
|
|
|
return sprintf('%s-Attachment nr. %s - %s', $this->job->key, strval($attachment->id), $attachment->filename);
|
|
}
|
|
|
|
/**
|
|
* @return Collection
|
|
*/
|
|
private function getAttachments(): Collection
|
|
{
|
|
$attachments = $this->repository->get();
|
|
|
|
return $attachments;
|
|
}
|
|
}
|