firefly-iii/app/Export/Collector/AttachmentCollector.php

150 lines
4.5 KiB
PHP
Raw Normal View History

2016-02-04 10:16:16 -06:00
<?php
2016-02-05 05:08:25 -06:00
declare(strict_types = 1);
2016-02-04 10:16:16 -06:00
/**
* AttachmentCollector.php
2016-04-01 09:44:46 -05:00
* Copyright (C) 2016 thegrumpydictator@gmail.com
2016-02-04 10:16:16 -06:00
*
* This software may be modified and distributed under the terms
* of the MIT license. See the LICENSE file for details.
*/
namespace FireflyIII\Export\Collector;
2016-02-07 02:11:46 -06:00
use Amount;
2016-02-04 10:16:16 -06:00
use Crypt;
use FireflyIII\Models\Attachment;
use FireflyIII\Models\ExportJob;
2016-02-07 02:11:46 -06:00
use FireflyIII\Models\TransactionJournal;
use FireflyIII\Repositories\Attachment\AttachmentRepositoryInterface;
2016-02-07 02:11:46 -06:00
use Illuminate\Contracts\Encryption\DecryptException;
2016-02-22 23:54:51 -06:00
use Illuminate\Support\Collection;
2016-02-04 10:16:16 -06:00
use Log;
2016-02-22 23:54:51 -06:00
use Storage;
2016-02-04 10:16:16 -06:00
/**
* Class AttachmentCollector
*
* @package FireflyIII\Export\Collector
*/
class AttachmentCollector extends BasicCollector implements CollectorInterface
{
2016-02-07 02:11:46 -06:00
/** @var string */
private $explanationString = '';
2016-02-22 23:54:51 -06:00
/** @var \Illuminate\Contracts\Filesystem\Filesystem */
private $exportDisk;
/** @var AttachmentRepositoryInterface */
private $repository;
2016-02-22 23:54:51 -06:00
/** @var \Illuminate\Contracts\Filesystem\Filesystem */
private $uploadDisk;
2016-02-04 10:16:16 -06:00
/**
* AttachmentCollector constructor.
*
* @param ExportJob $job
*/
public function __construct(ExportJob $job)
{
$this->repository = app('FireflyIII\Repositories\Attachment\AttachmentRepositoryInterface');
2016-02-22 23:54:51 -06:00
// make storage:
$this->uploadDisk = Storage::disk('upload');
$this->exportDisk = Storage::disk('export');
2016-02-04 10:16:16 -06:00
parent::__construct($job);
}
2016-02-05 08:41:40 -06:00
/**
2016-04-06 09:37:28 -05:00
* @return bool
2016-02-05 08:41:40 -06:00
*/
2016-04-06 09:37:28 -05:00
public function run(): bool
2016-02-04 10:16:16 -06:00
{
// grab all the users attachments:
2016-02-22 23:54:51 -06:00
$attachments = $this->getAttachments();
2016-02-04 10:16:16 -06:00
/** @var Attachment $attachment */
foreach ($attachments as $attachment) {
2016-02-22 23:54:51 -06:00
$this->exportAttachment($attachment);
2016-02-04 10:16:16 -06:00
}
2016-02-07 02:11:46 -06:00
// put the explanation string in a file and attach it as well.
2016-02-22 23:54:51 -06:00
$file = $this->job->key . '-Source of all your attachments explained.txt';
$this->exportDisk->put($file, $this->explanationString);
Log::debug('Also put explanation file "' . $file . '" in the zip.');
$this->getFiles()->push($file);
2016-04-06 09:37:28 -05:00
return true;
2016-02-07 02:11:46 -06:00
}
/**
* @param Attachment $attachment
*/
private function explain(Attachment $attachment)
{
/** @var TransactionJournal $journal */
$journal = $attachment->attachable;
2016-02-07 02:19:51 -06:00
$args = [
'attachment_name' => $attachment->filename,
'attachment_id' => $attachment->id,
'type' => strtolower($journal->transactionType->type),
'description' => $journal->description,
'journal_id' => $journal->id,
2016-02-10 09:23:37 -06:00
'date' => $journal->date->formatLocalized(strval(trans('config.month_and_day'))),
2016-02-07 02:19:51 -06:00
'amount' => Amount::formatJournal($journal, false),
];
$string = trans('firefly.attachment_explanation', $args) . "\n";
2016-02-07 02:11:46 -06:00
$this->explanationString .= $string;
2016-02-04 10:16:16 -06:00
}
2016-02-22 23:54:51 -06:00
/**
* @param Attachment $attachment
*
* @return bool
*/
private function exportAttachment(Attachment $attachment): bool
{
$file = $attachment->fileName();
Log::debug('Original file is at "' . $file . '".');
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);
Log::debug('Stored file content in new file "' . $exportFile . '", which will be in the final zip file.');
// 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();
Log::debug('Found ' . $attachments->count() . ' attachments.');
return $attachments;
}
2016-02-10 09:01:18 -06:00
}