diff --git a/plugins/ImageThumbnail/Controller/ImageThumbnail.php b/plugins/ImageThumbnail/Controller/ImageThumbnail.php new file mode 100644 index 0000000000..daa2ad651b --- /dev/null +++ b/plugins/ImageThumbnail/Controller/ImageThumbnail.php @@ -0,0 +1,53 @@ +. + +// }}} + +namespace Plugin\ImageThumbnail\Controller; + +use App\Core\Controller; +use App\Core\DB\DB; +use App\Util\Common; +use Symfony\Component\HttpFoundation\Request; + +class ImageThumbnail extends Controller +{ + /** + * Get a thumbnail for the attachment with id $id + */ + public function thumbnail(Request $request, int $id) + { + $attachemnt = DB::findOneBy('attachment', ['id' => $id]); + if (!is_null($attachemnt->getScope())) { + // && ($attachemnt->scope | VisibilityScope::PUBLIC) != 0 + // $user = Common::ensureLoggedIn(); + assert(false, 'Attachment scope not implemented'); + } + + // TODO rate limit + + $max_width = Common::config('thumbnail', 'width'); + $max_height = Common::config('thumbnail', 'height'); + $width = Common::clamp($this->int('w') ?? $max_width, min: 0, max: $max_width); + $height = Common::clamp($this->int('h') ?? $max_height, min: 0, max: $max_height); + $crop = $this->bool('c') ?? false; + + dd($width, $height, $crop); + } +} diff --git a/plugins/ImageThumbnail/ImageThumbnail.php b/plugins/ImageThumbnail/ImageThumbnail.php new file mode 100644 index 0000000000..fb59331b86 --- /dev/null +++ b/plugins/ImageThumbnail/ImageThumbnail.php @@ -0,0 +1,33 @@ +. +// }}} + +namespace Plugin\ImageThumbnail; + +use App\Core\Event; +use App\Core\Modules\Module; +use App\Core\Router\RouteLoader; + +class ImageThumbnail extends Module +{ + public function onAddRoute(RouteLoader $r) + { + $r->connect('thumbnail', '/thumbnail/{id<\d+>}', [Controller\ImageThumbnail::class, 'thumbnail']); + return Event::next; + } +}