We don’t need the complexity of S3. Sepcifically the complexity of managing my own AWS account, flysystem made the Laravel side easy. A command is added to copy the the S3 files over to local storage.
82 lines
2.5 KiB
PHP
82 lines
2.5 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Jobs;
|
|
|
|
use GuzzleHttp\Client;
|
|
use GuzzleHttp\Exception\GuzzleException;
|
|
use Illuminate\Bus\Queueable;
|
|
use Illuminate\Contracts\Filesystem\FileNotFoundException;
|
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
|
use Illuminate\FileSystem\FileSystem;
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
use Illuminate\Queue\SerializesModels;
|
|
|
|
class DownloadWebMention implements ShouldQueue
|
|
{
|
|
use InteractsWithQueue;
|
|
use Queueable;
|
|
use SerializesModels;
|
|
|
|
/**
|
|
* Create a new job instance.
|
|
*/
|
|
public function __construct(
|
|
protected string $source
|
|
) {}
|
|
|
|
/**
|
|
* Execute the job.
|
|
*
|
|
* @throws GuzzleException
|
|
* @throws FileNotFoundException
|
|
*/
|
|
public function handle(Client $guzzle): void
|
|
{
|
|
$response = $guzzle->request('GET', $this->source);
|
|
//4XX and 5XX responses should get Guzzle to throw an exception,
|
|
//Laravel should catch and retry these automatically.
|
|
if ($response->getStatusCode() === 200) {
|
|
$filesystem = new FileSystem;
|
|
$filename = storage_path('HTML') . '/' . $this->createFilenameFromURL($this->source);
|
|
//backup file first
|
|
$filenameBackup = $filename . '.' . date('Y-m-d') . '.backup';
|
|
if ($filesystem->exists($filename)) {
|
|
$filesystem->copy($filename, $filenameBackup);
|
|
}
|
|
//check if base directory exists
|
|
if (! $filesystem->exists($filesystem->dirname($filename))) {
|
|
$filesystem->makeDirectory(
|
|
$filesystem->dirname($filename),
|
|
0755, //mode
|
|
true //recursive
|
|
);
|
|
}
|
|
//save new HTML
|
|
$filesystem->put(
|
|
$filename,
|
|
(string) $response->getBody()
|
|
);
|
|
//remove backup if the same
|
|
if ($filesystem->exists($filenameBackup)) {
|
|
if ($filesystem->get($filename) === $filesystem->get($filenameBackup)) {
|
|
$filesystem->delete($filenameBackup);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Create a file path from a URL. This is used when caching the HTML response.
|
|
*/
|
|
private function createFilenameFromURL(string $url): string
|
|
{
|
|
$filepath = str_replace(['https://', 'http://'], ['https/', 'http/'], $url);
|
|
if (str_ends_with($filepath, '/')) {
|
|
$filepath .= 'index.html';
|
|
}
|
|
|
|
return $filepath;
|
|
}
|
|
}
|