forked from projects/file-explorer
Compare commits
4 Commits
b189753c1e
...
main
Author | SHA1 | Date | |
---|---|---|---|
557dda99d6 | |||
a5c9596397 | |||
461361d2ed | |||
a67b93ac99 |
@ -9,15 +9,12 @@ jobs:
|
|||||||
build:
|
build:
|
||||||
runs-on: remote
|
runs-on: remote
|
||||||
steps:
|
steps:
|
||||||
- uses: https://git.simonis.lol/actions/checkout@v4
|
|
||||||
- uses: https://git.simonis.lol/actions/login@v1
|
|
||||||
with:
|
|
||||||
registry: git.simonis.lol
|
|
||||||
username: ${{ vars.DOCKER_USER }}
|
|
||||||
password: ${{ vars.DOCKER_PW }}
|
|
||||||
|
|
||||||
- name: build
|
- name: Checkout
|
||||||
run: docker build -t git.simonis.lol/sites/file-explorer:latest .
|
uses: https://git.simonis.lol/actions/checkout@v2
|
||||||
|
|
||||||
- name: push
|
- name: Build
|
||||||
run: docker push git.simonis.lol/sites/file-explorer:latest
|
run: docker buildx build -t git.simonis.lol/projects/file-explorer:latest .
|
||||||
|
|
||||||
|
- name: Push
|
||||||
|
run: docker push git.simonis.lol/projects/file-explorer:latest
|
@ -23,7 +23,8 @@
|
|||||||
"symfony/yaml": "7.1.*",
|
"symfony/yaml": "7.1.*",
|
||||||
"symfonycasts/tailwind-bundle": "^0.6.1",
|
"symfonycasts/tailwind-bundle": "^0.6.1",
|
||||||
"twig/extra-bundle": "^2.12|^3.0",
|
"twig/extra-bundle": "^2.12|^3.0",
|
||||||
"twig/twig": "^2.12|^3.0"
|
"twig/twig": "^2.12|^3.0",
|
||||||
|
"ext-fileinfo": "*"
|
||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
"allow-plugins": {
|
"allow-plugins": {
|
||||||
|
@ -5,7 +5,6 @@ namespace App\Controller;
|
|||||||
use App\Service\FileSystemService;
|
use App\Service\FileSystemService;
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
use Symfony\Component\HttpFoundation\BinaryFileResponse;
|
use Symfony\Component\HttpFoundation\BinaryFileResponse;
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
|
||||||
use Symfony\Component\HttpFoundation\ResponseHeaderBag;
|
use Symfony\Component\HttpFoundation\ResponseHeaderBag;
|
||||||
use Symfony\Component\Routing\Attribute\Route;
|
use Symfony\Component\Routing\Attribute\Route;
|
||||||
|
|
||||||
@ -15,7 +14,7 @@ class ServeFileController extends AbstractController
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
#[Route("/serve-file/{filePath}", name: "serve_file")]
|
#[Route("/serve/{filePath}", name: "serve_file")]
|
||||||
public function __invoke(string $filePath): BinaryFileResponse
|
public function __invoke(string $filePath): BinaryFileResponse
|
||||||
{
|
{
|
||||||
$file = $this->fileSystemService->getFile($filePath);
|
$file = $this->fileSystemService->getFile($filePath);
|
||||||
|
@ -14,6 +14,7 @@ readonly class DirContent
|
|||||||
private string $type,
|
private string $type,
|
||||||
private string $path,
|
private string $path,
|
||||||
private string $content,
|
private string $content,
|
||||||
|
private string $mimeType,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -24,7 +25,8 @@ readonly class DirContent
|
|||||||
$fileInfo->getSize() ?? 0,
|
$fileInfo->getSize() ?? 0,
|
||||||
$fileInfo->getType() ?? 'N/A',
|
$fileInfo->getType() ?? 'N/A',
|
||||||
$fileInfo->getPath(),
|
$fileInfo->getPath(),
|
||||||
$content
|
$content,
|
||||||
|
mime_content_type($fileInfo->getPath() . '/' . $fileInfo->getFilename()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,6 +59,11 @@ readonly class DirContent
|
|||||||
return $this->content;
|
return $this->content;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getMimeType(): string
|
||||||
|
{
|
||||||
|
return $this->mimeType;
|
||||||
|
}
|
||||||
|
|
||||||
private function getHumanReadableSize(): string
|
private function getHumanReadableSize(): string
|
||||||
{
|
{
|
||||||
$bytes = $this->size;
|
$bytes = $this->size;
|
||||||
|
@ -15,7 +15,11 @@
|
|||||||
</a>
|
</a>
|
||||||
|
|
||||||
<div class="mt-6 text-gray-700 overflow-auto max-h-96">
|
<div class="mt-6 text-gray-700 overflow-auto max-h-96">
|
||||||
<p class="whitespace-pre-wrap leading-relaxed break-all text-balance">{{ file.content|raw }}</p>
|
{% if file.mimeType starts with 'image' %}
|
||||||
|
<img src="{{ path('serve_file', {filePath: file.name}) }}" alt="">
|
||||||
|
{% else %}
|
||||||
|
<p class="whitespace-pre-wrap leading-relaxed break-all text-balance">{{ file.content|raw }}</p>
|
||||||
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
Reference in New Issue
Block a user