Skip to main content

Download files

Usually static files and downloads should be performed through an interaction with the CMS API, the files are stored there and the API expose the endpoints for downloading them. Nonetheless there are still times where you want to make some static frontend files downloadable. To achieve that you can place them in src/assets/media and quickly use the helper functions download or downloadWithAuth to output their links.

In your template, e.g. src/routes/home

<a href="{{ download('example.pdf') }}">Download file</a>

See more about these helpers in their docs.

Custom implementations

Despite the helpers you might still want to create your own download implementation, here is an example:

Download route through fragments

In src/fragments/routes.php add

<?php

use Illuminate\Support\Facades\Route;
use resources\fragments\Download;

Route::get("download/{path}", [Download::class, "get"]);

Now create a file src/fragments/Download.php along the lines of:

<?php

namespace resources\fragments;

class Download
{
public function get(string $path)
{
$fullpath = public_path("assets/media/" . $name . "." . $extension);

// maybe you can have here some custom logic

if (file_exists($fullpath)) {
// to force the download of the file:
// return response()->download($fullpath);

// to display the file in the browser (whether that is possible):
return response()->file($fullpath);
}

abort(404);
}
}

In your template, e.g. src/routes/home

<a href="/_/fragments/download/myfile.xls">Download file</a>