streams/Code/Module/Embedfiles.php

262 lines
8.5 KiB
PHP
Raw Normal View History

<?php
namespace Code\Module;
use App;
use Code\Web\Controller;
use Code\Lib\Channel;
use Code\Render\Theme;
require_once('include/attach.php');
require_once('include/photos.php');
2023-02-18 16:28:36 +00:00
class Embedfiles extends Controller
{
2023-02-18 18:25:06 +00:00
/** This is the POST destination for the embedfiles button */
public function post()
{
// The admin tools for setting a site logo and cover photo set the channel_id explicitly
// to the 'sys' channel and use stored resources for that channel.
// Legacy behaviour uses the local logged in channel.
if (argc() > 2 && is_site_admin() && intval(argv(2))) {
$channel_id = argv(2);
} else {
$channel_id = local_channel();
}
2023-02-18 18:25:06 +00:00
/* start add new */
$observer = App::get_observer();
2023-02-18 20:40:54 +00:00
$result = attach_list_files("ray", $observer);
json_return_and_die(['status' => true, 'content' => $result]);
2023-02-18 18:25:06 +00:00
/* end add new */
if (argc() > 1 && argv(1) === 'album') {
// API: /embedphotos/album
$name = (x($_POST, 'name') ? $_POST['name'] : null);
if (!$name) {
json_return_and_die(['errormsg' => 'Error retrieving album', 'status' => false]);
}
$album = $this->embedphotos_widget_album(['channel_id' => $channel_id, 'album' => $name]);
json_return_and_die(['status' => true, 'content' => $album]);
}
if (argc() > 1 && argv(1) === 'albumlist') {
// API: /embedphotos/albumlist
$album_list = $this->embedphotos_album_list($channel_id);
json_return_and_die(['status' => true, 'albumlist' => $album_list]);
}
if (argc() > 1 && argv(1) === 'photolink') {
// API: /embedphotos/photolink
$href = (x($_POST, 'href') ? $_POST['href'] : null);
if (!$href) {
json_return_and_die(['errormsg' => 'Error retrieving link ' . $href, 'status' => false]);
}
$tmp = explode('/', $href);
$resource_id = array_pop($tmp);
$x = self::photolink($resource_id, $channel_id);
if ($x) {
json_return_and_die(['status' => true, 'photolink' => $x, 'resource_id' => $resource_id]);
}
json_return_and_die(['errormsg' => 'Error retrieving resource ' . $resource_id, 'status' => false]);
}
}
protected static function photolink($resource, $channel_id = 0)
{
if (intval($channel_id)) {
$channel = Channel::from_id($channel_id);
} else {
$channel = App::get_channel();
}
$output = EMPTY_STR;
if ($channel) {
$resolution = 1;
$r = q(
"select mimetype, height, width, title from photo where resource_id = '%s' and imgscale = %d and uid = %d limit 1",
dbesc($resource),
intval($resolution),
intval($channel['channel_id'])
);
if (!$r) {
return $output;
}
if ($r[0]['mimetype'] === 'image/jpeg') {
$ext = '.jpg';
} elseif ($r[0]['mimetype'] === 'image/png') {
$ext = '.png';
} elseif ($r[0]['mimetype'] === 'image/gif') {
$ext = '.gif';
} else {
$ext = EMPTY_STR;
}
$alt = $r[0]['title'];
if (!$alt) {
$a = q(
"select filename from attach where hash = '%s' and uid = %d limit 1",
dbesc($resource),
intval($channel['channel_id'])
);
if ($a) {
$alt = $a[0]['filename'];
} else {
$alt = t('Image/photo');
}
}
$alt = ' alt="' . $alt . '"';
$output = '[zrl=' . z_root() . '/photos/' . $channel['channel_address'] . '/image/' . $resource . ']'
. '[zmg width="' . $r[0]['width'] . '" height="' . $r[0]['height'] . '"' . $alt . ']'
. z_root() . '/photo/' . $resource . '-' . $resolution . $ext . '[/zmg][/zrl]';
return $output;
}
return '';
}
/**
* Copied from include/widgets.php::widget_album() with a modification to get the profile_uid from
* the input array as in widget_item()
*
* @param array $args
* @return string with HTML
*/
public function embedphotos_widget_album($args)
{
$channel_id = 0;
if (array_key_exists('channel_id', $args)) {
$channel_id = $args['channel_id'];
$channel = Channel::from_id($channel_id);
}
if (!$channel_id) {
return '';
}
$owner_uid = $channel_id;
require_once('include/security.php');
$sql_extra = permissions_sql($channel_id);
if (!perm_is_allowed($channel_id, get_observer_hash(), 'view_storage')) {
return '';
}
if ($args['album']) {
$album = (($args['album'] === '/') ? '' : $args['album']);
}
if ($args['title']) {
$title = $args['title'];
}
/**
* This may return incorrect permissions if you have multiple directories of the same name.
* It is a limitation of the photo table using a name for a photo album instead of a folder hash
*/
if ($album) {
$x = q(
"select hash from attach where filename = '%s' and uid = %d limit 1",
dbesc($album),
intval($owner_uid)
);
if ($x) {
$y = attach_can_view_folder($owner_uid, get_observer_hash(), $x[0]['hash']);
if (!$y) {
return '';
}
}
}
$order = 'DESC';
$r = q(
"SELECT p.resource_id, p.id, p.filename, p.mimetype, p.imgscale, p.description, p.created FROM photo p INNER JOIN
(SELECT resource_id, max(imgscale) imgscale FROM photo WHERE uid = %d AND album = '%s' AND imgscale <= 4
AND photo_usage IN ( %d, %d ) $sql_extra GROUP BY resource_id) ph
ON (p.resource_id = ph.resource_id AND p.imgscale = ph.imgscale)
ORDER BY created $order",
intval($owner_uid),
dbesc($album),
intval(PHOTO_NORMAL),
intval(PHOTO_PROFILE)
);
// We will need this to map mimetypes to appropriate file extensions
$ph = photo_factory('');
$phototypes = $ph->supportedTypes();
$photos = [];
if ($r) {
$twist = 'rotright';
foreach ($r as $rr) {
if ($twist == 'rotright') {
$twist = 'rotleft';
} else {
$twist = 'rotright';
}
$ext = $phototypes[$rr['mimetype']];
$imgalt_e = $rr['filename'];
$desc_e = $rr['description'];
$imagelink = (z_root() . '/photos/' . $channel['channel_address'] . '/image/' . $rr['resource_id']
. (($_GET['order'] === 'posted') ? '?f=&order=posted' : ''));
$photos[] = [
'id' => $rr['id'],
'twist' => ' ' . $twist . rand(2, 4),
'link' => $imagelink,
'title' => t('View Photo'),
'src' => z_root() . '/photo/' . $rr['resource_id'] . '-' . $rr['imgscale'] . '.' . $ext,
'alt' => $imgalt_e,
'desc' => $desc_e,
'ext' => $ext,
'hash' => $rr['resource_id'],
'unknown' => t('Unknown')
];
}
}
$o = replace_macros(Theme::get_template('photo_album.tpl'), [
'$photos' => $photos,
'$album' => (($title) ? $title : $album),
'$album_id' => rand(),
'$album_edit' => [t('Edit Album'), false],
'$can_post' => false,
'$upload' => [t('Upload'), z_root() . '/photos/' . $channel['channel_address'] . '/upload/' . bin2hex($album)],
'$order' => false,
'$upload_form' => false,
'$no_fullscreen_btn' => true
]);
return $o;
}
public function embedphotos_album_list($channel_id)
{
$channel = Channel::from_id($channel_id);
$p = photos_albums_list($channel, App::get_observer());
if ($p['success']) {
return $p['albums'];
} else {
return null;
}
}
}