* @author Fabio Comuni <fabrixxm@kirgroup.com>
*/
-require_once('include/Photo.php');
+use Friendica\App;
+use Friendica\Core\L10n;
+use Friendica\Core\Renderer;
+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) {
-
+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 = array(array("", t("Photos")));
+ $path = [["", L10n::t("Photos")]];
$albums = false;
$sql_extra = "";
$sql_extra2 = " ORDER BY created DESC LIMIT 0, 10";
- if ($a->argc==2){
+ if ($a->argc==2) {
$albums = q("SELECT distinct(`album`) AS `album` FROM `photo` WHERE `uid` = %d AND `album` != '%s' AND `album` != '%s' ",
intval(local_user()),
- dbesc('Contact Photos'),
- dbesc( t('Contact Photos'))
+ DBA::escape('Contact Photos'),
+ DBA::escape(L10n::t('Contact Photos'))
);
- function _map_folder1($el){return array(bin2hex($el['album']),$el['album']);};
- $albums = array_map( "_map_folder1" , $albums);
+ function _map_folder1($el)
+ {
+ return [bin2hex($el['album']),$el['album']];
+ };
+ $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' ",dbesc($album));
+ $sql_extra = sprintf("AND `album` = '%s' ", DBA::escape($album));
$sql_extra2 = "";
- $path[]=array($a->argv[2], $album);
+ $path[] = [$a->argv[2], $album];
}
- $r = q("SELECT `resource-id`, `id`, `filename`, type, min(`scale`) AS `hiq`,max(`scale`) AS `loq`, `desc`
+ $r = q("SELECT `resource-id`, ANY_VALUE(`id`) AS `id`, ANY_VALUE(`filename`) AS `filename`, ANY_VALUE(`type`) AS `type`,
+ min(`scale`) AS `hiq`, max(`scale`) AS `loq`, ANY_VALUE(`desc`) AS `desc`, ANY_VALUE(`created`) AS `created`
FROM `photo` WHERE `uid` = %d $sql_extra AND `album` != '%s' AND `album` != '%s'
GROUP BY `resource-id` $sql_extra2",
intval(local_user()),
- dbesc('Contact Photos'),
- dbesc( t('Contact Photos'))
+ DBA::escape('Contact Photos'),
+ DBA::escape(L10n::t('Contact Photos'))
);
- function _map_files1($rr){
- $a = get_app();
- $types = Photo::supportedTypes();
+ function _map_files1($rr)
+ {
+ $a = \get_app();
+ $types = Image::supportedTypes();
$ext = $types[$rr['type']];
-
- if($a->theme['template_engine'] === 'internal') {
- $filename_e = template_escape($rr['filename']);
- }
- else {
- $filename_e = $rr['filename'];
- }
+ $filename_e = $rr['filename'];
// Take the largest picture that is smaller or equal 640 pixels
$p = q("SELECT `scale` FROM `photo` WHERE `resource-id` = '%s' AND `height` <= 640 AND `width` <= 640 ORDER BY `resource-id`, `scale` LIMIT 1",
- dbesc($rr['resource-id']));
- if ($p)
+ DBA::escape($rr['resource-id']));
+ if ($p) {
$scale = $p[0]["scale"];
- else
+ } else {
$scale = $rr['loq'];
+ }
- return array(
- App::get_baseurl() . '/photos/' . $a->user['nickname'] . '/image/' . $rr['resource-id'],
+ return [
+ System::baseUrl() . '/photos/' . $a->user['nickname'] . '/image/' . $rr['resource-id'],
$filename_e,
- App::get_baseurl() . '/photo/' . $rr['resource-id'] . '-' . $scale . '.'. $ext
- );
+ System::baseUrl() . '/photo/' . $rr['resource-id'] . '-' . $scale . '.'. $ext
+ ];
}
$files = array_map("_map_files1", $r);
- $tpl = get_markup_template($template_file);
+ $tpl = Renderer::getMarkupTemplate($template_file);
- $o = replace_macros($tpl, array(
+ $o = Renderer::replaceMacros($tpl, [
'$type' => 'image',
- '$baseurl' => App::get_baseurl(),
'$path' => $path,
'$folders' => $albums,
'$files' => $files,
- '$cancel' => t('Cancel'),
+ '$cancel' => L10n::t('Cancel'),
'$nickname' => $a->user['nickname'],
- ));
-
+ '$upload' => L10n::t('Upload')
+ ]);
break;
case "file":
intval(local_user())
);
- function _map_files2($rr){
- $a = get_app();
- list($m1,$m2) = explode("/",$rr['filetype']);
+ function _map_files2($rr)
+ {
+ list($m1, $m2) = explode("/", $rr['filetype']);
$filetype = ( (file_exists("images/icons/$m1.png"))?$m1:"zip");
+ $filename_e = $rr['filename'];
- if ($a->theme['template_engine'] === 'internal') {
- $filename_e = template_escape($rr['filename']);
- } else {
- $filename_e = $rr['filename'];
- }
-
- return array( App::get_baseurl() . '/attach/' . $rr['id'], $filename_e, App::get_baseurl() . '/images/icons/16/' . $filetype . '.png');
+ return [System::baseUrl() . '/attach/' . $rr['id'], $filename_e, System::baseUrl() . '/images/icons/16/' . $filetype . '.png'];
}
$files = array_map("_map_files2", $files);
- $tpl = get_markup_template($template_file);
- $o = replace_macros($tpl, array(
+ $tpl = Renderer::getMarkupTemplate($template_file);
+ $o = Renderer::replaceMacros($tpl, [
'$type' => 'file',
- '$baseurl' => App::get_baseurl(),
- '$path' => array( array( "", t("Files")) ),
+ '$path' => [ [ "", L10n::t("Files")] ],
'$folders' => false,
- '$files' =>$files,
- '$cancel' => t('Cancel'),
+ '$files' => $files,
+ '$cancel' => L10n::t('Cancel'),
'$nickname' => $a->user['nickname'],
- ));
-
+ '$upload' => L10n::t('Upload')
+ ]);
}
break;
}
- if (x($_GET,'mode')) {
+ if (!empty($_GET['mode'])) {
return $o;
} else {
echo $o;
- killme();
+ exit();
}
-
-
}