mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-12-24 22:13:17 +00:00
Merge pull request #4510 from pixelfed/staging
Update StatusRemoteUpdatePipeline, fix missing mime and size attribut…
This commit is contained in:
commit
924ce5eea9
3 changed files with 71 additions and 0 deletions
|
@ -22,6 +22,7 @@
|
||||||
- Update console kernel, add import upload gc ([afe6948d](https://github.com/pixelfed/pixelfed/commit/afe6948d))
|
- Update console kernel, add import upload gc ([afe6948d](https://github.com/pixelfed/pixelfed/commit/afe6948d))
|
||||||
- Update ImportService, filter deleted posts from getImportedPosts endpoint ([10dd348c](https://github.com/pixelfed/pixelfed/commit/10dd348c))
|
- Update ImportService, filter deleted posts from getImportedPosts endpoint ([10dd348c](https://github.com/pixelfed/pixelfed/commit/10dd348c))
|
||||||
- Update FixStatusCount, improve command and support remote count resync ([04f4f8ba](https://github.com/pixelfed/pixelfed/commit/04f4f8ba))
|
- Update FixStatusCount, improve command and support remote count resync ([04f4f8ba](https://github.com/pixelfed/pixelfed/commit/04f4f8ba))
|
||||||
|
- Update StatusRemoteUpdatePipeline, fix missing mime and size attributes that cause empty media previews on our mobile app ([ea54413e](https://github.com/pixelfed/pixelfed/commit/ea54413e))
|
||||||
- ([](https://github.com/pixelfed/pixelfed/commit/))
|
- ([](https://github.com/pixelfed/pixelfed/commit/))
|
||||||
|
|
||||||
## [v0.11.8 (2023-05-29)](https://github.com/pixelfed/pixelfed/compare/v0.11.7...v0.11.8)
|
## [v0.11.8 (2023-05-29)](https://github.com/pixelfed/pixelfed/compare/v0.11.7...v0.11.8)
|
||||||
|
|
56
app/Console/Commands/FetchMissingMediaMimeType.php
Normal file
56
app/Console/Commands/FetchMissingMediaMimeType.php
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Console\Commands;
|
||||||
|
|
||||||
|
use Illuminate\Console\Command;
|
||||||
|
use App\Media;
|
||||||
|
use Illuminate\Support\Facades\Http;
|
||||||
|
use App\Services\MediaService;
|
||||||
|
use App\Services\StatusService;
|
||||||
|
|
||||||
|
class FetchMissingMediaMimeType extends Command
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The name and signature of the console command.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $signature = 'app:fetch-missing-media-mime-type';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The console command description.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $description = 'Command description';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the console command.
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
foreach(Media::whereNotNull(['remote_url', 'status_id'])->whereNull('mime')->lazyByIdDesc(50, 'id') as $media) {
|
||||||
|
$res = Http::retry(2, 100, throw: false)->head($media->remote_url);
|
||||||
|
|
||||||
|
if(!$res->successful()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!in_array($res->header('content-type'), explode(',',config('pixelfed.media_types')))) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$media->mime = $res->header('content-type');
|
||||||
|
|
||||||
|
if($res->hasHeader('content-length')) {
|
||||||
|
$media->size = $res->header('content-length');
|
||||||
|
}
|
||||||
|
|
||||||
|
$media->save();
|
||||||
|
|
||||||
|
MediaService::del($media->status_id);
|
||||||
|
StatusService::del($media->status_id);
|
||||||
|
$this->info('mid:'.$media->id . ' (' . $res->header('content-type') . ':' . $res->header('content-length') . ' bytes)');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -15,6 +15,7 @@ use App\Status;
|
||||||
use App\Models\StatusEdit;
|
use App\Models\StatusEdit;
|
||||||
use App\Services\StatusService;
|
use App\Services\StatusService;
|
||||||
use Purify;
|
use Purify;
|
||||||
|
use Illuminate\Support\Facades\Http;
|
||||||
|
|
||||||
class StatusRemoteUpdatePipeline implements ShouldQueue
|
class StatusRemoteUpdatePipeline implements ShouldQueue
|
||||||
{
|
{
|
||||||
|
@ -89,13 +90,26 @@ class StatusRemoteUpdatePipeline implements ShouldQueue
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$nm->each(function($n, $key) use($status) {
|
$nm->each(function($n, $key) use($status) {
|
||||||
|
$res = Http::retry(3, 100, throw: false)->head($n['url']);
|
||||||
|
|
||||||
|
if(!$res->successful()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!in_array($res->header('content-type'), explode(',',config('pixelfed.media_types')))) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
$m = new Media;
|
$m = new Media;
|
||||||
$m->status_id = $status->id;
|
$m->status_id = $status->id;
|
||||||
$m->profile_id = $status->profile_id;
|
$m->profile_id = $status->profile_id;
|
||||||
$m->remote_media = true;
|
$m->remote_media = true;
|
||||||
$m->media_path = $n['url'];
|
$m->media_path = $n['url'];
|
||||||
|
$m->mime = $res->header('content-type');
|
||||||
|
$m->size = $res->hasHeader('content-length') ? $res->header('content-length') : null;
|
||||||
$m->caption = isset($n['name']) && !empty($n['name']) ? Purify::clean($n['name']) : null;
|
$m->caption = isset($n['name']) && !empty($n['name']) ? Purify::clean($n['name']) : null;
|
||||||
$m->remote_url = $n['url'];
|
$m->remote_url = $n['url'];
|
||||||
|
$m->blurhash = isset($n['blurhash']) && (strlen($n['blurhash']) < 50) ? $n['blurhash'] : null;
|
||||||
$m->width = isset($n['width']) && !empty($n['width']) ? $n['width'] : null;
|
$m->width = isset($n['width']) && !empty($n['width']) ? $n['width'] : null;
|
||||||
$m->height = isset($n['height']) && !empty($n['height']) ? $n['height'] : null;
|
$m->height = isset($n['height']) && !empty($n['height']) ? $n['height'] : null;
|
||||||
$m->skip_optimize = true;
|
$m->skip_optimize = true;
|
||||||
|
|
Loading…
Reference in a new issue