use Friendica\Core\System;
use Friendica\Database\DBA;
use Friendica\Object\Image;
+use Friendica\Util\Strings;
/**
* @param App $a
+ * @return string
+ * @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/
function fbrowser_content(App $a)
{
if (!local_user()) {
- killme();
+ exit();
}
if ($a->argc == 1) {
- killme();
+ exit();
}
- $template_file = "filebrowser.tpl";
- $mode = "";
- if (x($_GET, 'mode')) {
- $mode = "?mode=".$_GET['mode'];
+ // Needed to match the correct template in a module that uses a different theme than the user/site/default
+ $theme = Strings::sanitizeFilePathItem(defaults($_GET, 'theme', null));
+ if ($theme && is_file("view/theme/$theme/config.php")) {
+ $a->setCurrentTheme($theme);
}
+ $template_file = "filebrowser.tpl";
+
+ $o = '';
+
switch ($a->argv[1]) {
case "image":
$path = [["", L10n::t("Photos")]];
$albums = array_map("_map_folder1", $albums);
}
- $album = "";
- if ($a->argc==3) {
+ if ($a->argc == 3) {
$album = hex2bin($a->argv[2]);
$sql_extra = sprintf("AND `album` = '%s' ", DBA::escape($album));
$sql_extra2 = "";
- $path[]=[$a->argv[2], $album];
+ $path[] = [$a->argv[2], $album];
}
$r = q("SELECT `resource-id`, ANY_VALUE(`id`) AS `id`, ANY_VALUE(`filename`) AS `filename`, ANY_VALUE(`type`) AS `type`,
function _map_files1($rr)
{
- $a = get_app();
+ $a = \get_app();
$types = Image::supportedTypes();
$ext = $types[$rr['type']];
$filename_e = $rr['filename'];
$o = Renderer::replaceMacros($tpl, [
'$type' => 'image',
- '$baseurl' => System::baseUrl(),
'$path' => $path,
'$folders' => $albums,
'$files' => $files,
function _map_files2($rr)
{
- $a = get_app();
- list($m1,$m2) = explode("/", $rr['filetype']);
+ list($m1, $m2) = explode("/", $rr['filetype']);
$filetype = ( (file_exists("images/icons/$m1.png"))?$m1:"zip");
$filename_e = $rr['filename'];
$tpl = Renderer::getMarkupTemplate($template_file);
$o = Renderer::replaceMacros($tpl, [
'$type' => 'file',
- '$baseurl' => System::baseUrl(),
'$path' => [ [ "", L10n::t("Files")] ],
'$folders' => false,
'$files' => $files,
break;
}
- if (x($_GET, 'mode')) {
+ if (!empty($_GET['mode'])) {
return $o;
} else {
echo $o;
- killme();
+ exit();
}
}