2010-08-06 00:15:24 -04:00
< ? php
2017-11-29 07:52:27 -05:00
/**
2021-03-29 02:40:20 -04:00
* @ copyright Copyright ( C ) 2010 - 2021 , the Friendica project
2020-02-09 10:18:46 -05:00
*
* @ license GNU AGPL version 3 or any later version
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation , either version 3 of the
* License , or ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU Affero General Public License for more details .
*
* You should have received a copy of the GNU Affero General Public License
* along with this program . If not , see < https :// www . gnu . org / licenses />.
*
2017-11-29 07:52:27 -05:00
*/
2018-01-24 21:08:45 -05:00
2017-04-30 00:07:00 -04:00
use Friendica\App ;
2017-12-04 09:04:36 -05:00
use Friendica\Content\Feature ;
2018-01-15 14:51:56 -05:00
use Friendica\Content\Nav ;
2018-10-24 02:15:24 -04:00
use Friendica\Content\Pager ;
2018-02-14 21:33:55 -05:00
use Friendica\Content\Text\BBCode ;
2021-07-24 06:09:39 -04:00
use Friendica\Content\Widget ;
2018-03-02 18:41:24 -05:00
use Friendica\Core\ACL ;
2020-09-09 16:49:03 -04:00
use Friendica\Core\Addon ;
2018-12-26 01:06:24 -05:00
use Friendica\Core\Hook ;
2018-10-29 17:20:46 -04:00
use Friendica\Core\Logger ;
2018-10-31 10:35:50 -04:00
use Friendica\Core\Renderer ;
2019-09-28 05:59:08 -04:00
use Friendica\Core\Session ;
2019-10-23 15:38:51 -04:00
use Friendica\Core\System ;
2018-07-20 08:19:26 -04:00
use Friendica\Database\DBA ;
2019-12-15 17:28:01 -05:00
use Friendica\DI ;
2017-12-07 09:04:24 -05:00
use Friendica\Model\Contact ;
2018-01-28 06:18:08 -05:00
use Friendica\Model\Item ;
2017-12-07 08:56:11 -05:00
use Friendica\Model\Photo ;
2021-01-15 23:11:28 -05:00
use Friendica\Model\Post ;
2021-08-08 06:14:56 -04:00
use Friendica\Model\Profile ;
2020-04-18 16:46:41 -04:00
use Friendica\Model\Tag ;
2018-06-18 16:36:34 -04:00
use Friendica\Model\User ;
2020-01-26 09:49:11 -05:00
use Friendica\Module\BaseProfile ;
2017-05-07 14:44:30 -04:00
use Friendica\Network\Probe ;
2017-12-07 08:56:11 -05:00
use Friendica\Object\Image ;
2019-10-23 18:25:43 -04:00
use Friendica\Protocol\Activity ;
2018-11-05 03:37:03 -05:00
use Friendica\Util\Crypto ;
2018-01-26 21:38:34 -05:00
use Friendica\Util\DateTimeFormat ;
2019-10-17 21:26:15 -04:00
use Friendica\Util\Images ;
2018-01-24 21:08:45 -05:00
use Friendica\Util\Map ;
2020-09-30 05:14:01 -04:00
use Friendica\Security\Security ;
2018-11-08 10:14:37 -05:00
use Friendica\Util\Strings ;
2019-05-26 09:00:19 -04:00
use Friendica\Util\Temporal ;
2018-11-05 07:40:18 -05:00
use Friendica\Util\XML ;
2021-07-24 06:09:39 -04:00
use Friendica\Network\HTTPException ;
2017-04-30 00:01:26 -04:00
2017-01-09 07:14:25 -05:00
function photos_init ( App $a ) {
2010-08-06 00:15:24 -04:00
2020-01-19 15:21:13 -05:00
if ( DI :: config () -> get ( 'system' , 'block_public' ) && ! Session :: isAuthenticated ()) {
2011-04-21 20:29:47 -04:00
return ;
}
2012-10-09 11:50:24 -04:00
2018-01-15 14:51:56 -05:00
Nav :: setSelected ( 'home' );
2015-09-30 12:50:44 -04:00
2021-07-25 09:08:22 -04:00
if ( DI :: args () -> getArgc () > 1 ) {
$owner = User :: getOwnerDataByNick ( DI :: args () -> getArgv ()[ 1 ]);
2010-08-06 00:15:24 -04:00
2021-07-24 06:09:39 -04:00
$is_owner = ( local_user () && ( local_user () == $owner [ 'uid' ]));
2015-12-01 12:31:08 -05:00
2021-07-24 06:09:39 -04:00
$albums = Photo :: getAlbums ( $owner [ 'uid' ]);
2012-11-02 07:20:12 -04:00
2021-07-24 06:09:39 -04:00
$albums_visible = (( intval ( $owner [ 'hidewall' ]) && ! Session :: isAuthenticated ()) ? false : true );
2015-06-27 08:10:43 -04:00
// add various encodings to the array so we can just loop through and pick them out in a template
2018-01-15 08:05:12 -05:00
$ret = [ 'success' => false ];
2015-06-27 08:10:43 -04:00
2016-10-22 06:14:41 -04:00
if ( $albums ) {
2017-03-25 09:56:23 -04:00
if ( $albums_visible ) {
2015-06-27 08:10:43 -04:00
$ret [ 'success' ] = true ;
2017-03-25 09:56:23 -04:00
}
2015-06-27 08:10:43 -04:00
2018-01-15 08:05:12 -05:00
$ret [ 'albums' ] = [];
2016-10-22 06:14:41 -04:00
foreach ( $albums as $k => $album ) {
2015-09-29 13:44:26 -04:00
//hide profile photos to others
2021-07-24 06:09:39 -04:00
if ( ! $is_owner && ! Session :: getRemoteContactID ( $owner [ 'uid' ]) && ( $album [ 'album' ] == DI :: l10n () -> t ( 'Profile Photos' )))
2015-09-29 13:44:26 -04:00
continue ;
2018-01-15 08:05:12 -05:00
$entry = [
2015-06-27 08:10:43 -04:00
'text' => $album [ 'album' ],
'total' => $album [ 'total' ],
2021-07-24 06:09:39 -04:00
'url' => 'photos/' . $owner [ 'nickname' ] . '/album/' . bin2hex ( $album [ 'album' ]),
2015-06-27 08:10:43 -04:00
'urlencode' => urlencode ( $album [ 'album' ]),
'bin2hex' => bin2hex ( $album [ 'album' ])
2018-01-15 08:05:12 -05:00
];
2015-06-27 08:10:43 -04:00
$ret [ 'albums' ][] = $entry ;
}
}
2021-07-24 06:09:39 -04:00
if ( local_user () && $owner [ 'uid' ] == local_user ()) {
2015-06-27 08:10:43 -04:00
$can_post = true ;
2018-07-10 08:27:56 -04:00
} else {
$can_post = false ;
2017-03-25 09:56:23 -04:00
}
2015-06-27 08:10:43 -04:00
2018-01-01 16:47:00 -05:00
if ( $ret [ 'success' ]) {
2018-10-31 10:44:06 -04:00
$photo_albums_widget = Renderer :: replaceMacros ( Renderer :: getMarkupTemplate ( 'photo_albums.tpl' ), [
2021-07-24 06:09:39 -04:00
'$nick' => $owner [ 'nickname' ],
2020-01-18 14:52:34 -05:00
'$title' => DI :: l10n () -> t ( 'Photo Albums' ),
'$recent' => DI :: l10n () -> t ( 'Recent Photos' ),
2018-01-01 16:47:00 -05:00
'$albums' => $ret [ 'albums' ],
2021-07-24 06:09:39 -04:00
'$upload' => [ DI :: l10n () -> t ( 'Upload New Photos' ), 'photos/' . $owner [ 'nickname' ] . '/upload' ],
2015-06-27 08:10:43 -04:00
'$can_post' => $can_post
2018-01-15 08:05:12 -05:00
]);
2015-06-27 08:10:43 -04:00
}
2010-08-06 00:15:24 -04:00
2019-12-30 14:02:09 -05:00
if ( empty ( DI :: page ()[ 'aside' ])) {
DI :: page ()[ 'aside' ] = '' ;
2017-03-25 09:56:23 -04:00
}
2018-07-22 21:19:28 -04:00
2021-07-24 06:09:39 -04:00
DI :: page ()[ 'aside' ] .= Widget\VCard :: getHTML ( $owner );
2018-07-30 00:41:20 -04:00
if ( ! empty ( $photo_albums_widget )) {
2019-12-30 14:02:09 -05:00
DI :: page ()[ 'aside' ] .= $photo_albums_widget ;
2018-07-30 00:41:20 -04:00
}
2011-06-02 01:06:53 -04:00
2018-10-31 10:44:06 -04:00
$tpl = Renderer :: getMarkupTemplate ( " photos_head.tpl " );
2018-07-22 21:19:28 -04:00
2019-12-30 14:02:09 -05:00
DI :: page ()[ 'htmlhead' ] .= Renderer :: replaceMacros ( $tpl ,[
2020-01-18 14:52:34 -05:00
'$ispublic' => DI :: l10n () -> t ( 'everybody' )
2018-01-15 08:05:12 -05:00
]);
2010-08-06 00:15:24 -04:00
}
2010-12-05 21:08:36 -05:00
2010-09-08 23:14:17 -04:00
return ;
2010-08-06 00:15:24 -04:00
}
2018-01-01 16:47:00 -05:00
function photos_post ( App $a )
{
2021-07-25 09:08:22 -04:00
$user = User :: getByNickname ( DI :: args () -> getArgv ()[ 1 ]);
2021-07-24 06:09:39 -04:00
if ( ! DBA :: isResult ( $user )) {
throw new HTTPException\NotFoundException ( DI :: l10n () -> t ( 'User not found.' ));
}
2019-10-17 21:26:15 -04:00
$phototypes = Images :: supportedTypes ();
2012-06-07 11:42:13 -04:00
2010-12-05 21:08:36 -05:00
$can_post = false ;
$visitor = 0 ;
2021-07-24 06:09:39 -04:00
$page_owner_uid = intval ( $user [ 'uid' ]);
$community_page = $user [ 'page-flags' ] == User :: PAGE_FLAGS_COMMUNITY ;
2010-12-05 21:08:36 -05:00
2017-12-28 15:37:23 -05:00
if ( local_user () && ( local_user () == $page_owner_uid )) {
2010-12-05 21:08:36 -05:00
$can_post = true ;
2019-09-28 05:59:08 -04:00
} elseif ( $community_page && ! empty ( Session :: getRemoteContactID ( $page_owner_uid ))) {
$contact_id = Session :: getRemoteContactID ( $page_owner_uid );
2019-09-28 01:37:24 -04:00
$can_post = true ;
$visitor = $contact_id ;
2010-12-05 21:08:36 -05:00
}
2010-08-06 00:15:24 -04:00
2017-12-28 15:37:23 -05:00
if ( ! $can_post ) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Permission denied.' ));
2018-12-26 00:40:12 -05:00
exit ();
2010-10-14 01:01:23 -04:00
}
2010-08-08 20:08:39 -04:00
2018-06-18 16:36:34 -04:00
$owner_record = User :: getOwnerDataById ( $page_owner_uid );
2010-08-08 20:08:39 -04:00
2018-06-18 16:36:34 -04:00
if ( ! $owner_record ) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Contact information unavailable' ));
2020-12-21 00:27:16 -05:00
DI :: logger () -> info ( 'photos_post: unable to locate contact record for page owner. uid=' . $page_owner_uid );
2018-12-26 00:40:12 -05:00
exit ();
2010-11-02 19:24:23 -04:00
}
2020-12-21 22:23:13 -05:00
$aclFormatter = DI :: aclFormatter ();
$str_contact_allow = isset ( $_REQUEST [ 'contact_allow' ]) ? $aclFormatter -> toString ( $_REQUEST [ 'contact_allow' ]) : $owner_record [ 'allow_cid' ] ? ? '' ;
$str_group_allow = isset ( $_REQUEST [ 'group_allow' ]) ? $aclFormatter -> toString ( $_REQUEST [ 'group_allow' ]) : $owner_record [ 'allow_gid' ] ? ? '' ;
$str_contact_deny = isset ( $_REQUEST [ 'contact_deny' ]) ? $aclFormatter -> toString ( $_REQUEST [ 'contact_deny' ]) : $owner_record [ 'deny_cid' ] ? ? '' ;
$str_group_deny = isset ( $_REQUEST [ 'group_deny' ]) ? $aclFormatter -> toString ( $_REQUEST [ 'group_deny' ]) : $owner_record [ 'deny_gid' ] ? ? '' ;
$visibility = $_REQUEST [ 'visibility' ] ? ? '' ;
if ( $visibility === 'public' ) {
// The ACL selector introduced in version 2019.12 sends ACL input data even when the Public visibility is selected
$str_contact_allow = $str_group_allow = $str_contact_deny = $str_group_deny = '' ;
} else if ( $visibility === 'custom' ) {
// Since we know from the visibility parameter the item should be private, we have to prevent the empty ACL
// case that would make it public. So we always append the author's contact id to the allowed contacts.
2020-12-21 00:27:16 -05:00
// See https://github.com/friendica/friendica/issues/9672
2020-12-21 22:23:13 -05:00
$str_contact_allow .= $aclFormatter -> toString ( Contact :: getPublicIdByUserId ( $page_owner_uid ));
2020-12-21 00:27:16 -05:00
}
2021-07-25 09:08:22 -04:00
if ( DI :: args () -> getArgc () > 3 && DI :: args () -> getArgv ()[ 2 ] === 'album' ) {
if ( ! Strings :: isHex ( DI :: args () -> getArgv ()[ 3 ])) {
2021-07-24 06:09:39 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . $user [ 'nickname' ] . '/album' );
2019-05-30 04:30:15 -04:00
}
2021-07-25 09:08:22 -04:00
$album = hex2bin ( DI :: args () -> getArgv ()[ 3 ]);
2010-08-08 20:08:39 -04:00
2020-08-18 18:18:48 -04:00
if ( $album === DI :: l10n () -> t ( 'Profile Photos' ) || $album === Photo :: CONTACT_PHOTOS || $album === DI :: l10n () -> t ( Photo :: CONTACT_PHOTOS )) {
2019-12-15 18:28:31 -05:00
DI :: baseUrl () -> redirect ( $_SESSION [ 'photo_return' ]);
2010-08-08 20:08:39 -04:00
return ; // NOTREACHED
}
2017-09-15 17:00:39 -04:00
$r = q ( " SELECT `album` FROM `photo` WHERE `album` = '%s' AND `uid` = %d " ,
2018-07-21 09:10:13 -04:00
DBA :: escape ( $album ),
2010-12-05 21:08:36 -05:00
intval ( $page_owner_uid )
2010-08-08 20:08:39 -04:00
);
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2018-07-21 08:46:04 -04:00
if ( ! DBA :: isResult ( $r )) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Album not found.' ));
2021-07-24 06:09:39 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . $user [ 'nickname' ] . '/album' );
2010-08-08 20:08:39 -04:00
return ; // NOTREACHED
}
2013-01-26 14:52:21 -05:00
// Check if the user has responded to a delete confirmation query
2018-09-11 00:10:11 -04:00
if ( ! empty ( $_REQUEST [ 'canceled' ])) {
2021-07-25 09:08:22 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . $user [ 'nickname' ] . '/album/' . DI :: args () -> getArgv ()[ 3 ]);
2013-01-26 14:52:21 -05:00
}
2018-01-01 16:47:00 -05:00
// RENAME photo album
2018-11-09 13:29:42 -05:00
$newalbum = Strings :: escapeTags ( trim ( $_POST [ 'albumname' ]));
2016-10-22 06:14:41 -04:00
if ( $newalbum != $album ) {
2010-08-08 20:08:39 -04:00
q ( " UPDATE `photo` SET `album` = '%s' WHERE `album` = '%s' AND `uid` = %d " ,
2018-07-21 09:10:13 -04:00
DBA :: escape ( $newalbum ),
DBA :: escape ( $album ),
2010-12-05 21:08:36 -05:00
intval ( $page_owner_uid )
2010-08-08 20:08:39 -04:00
);
2016-12-25 10:58:38 -05:00
// Update the photo albums cache
2018-01-03 22:36:15 -05:00
Photo :: clearAlbumCache ( $page_owner_uid );
2016-12-25 10:58:38 -05:00
2021-08-09 15:48:39 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . $a -> getLoggedInUserNickname () . '/album/' . bin2hex ( $newalbum ));
2010-08-08 20:08:39 -04:00
return ; // NOTREACHED
}
2015-09-29 18:19:54 -04:00
/*
2019-05-01 19:36:14 -04:00
* DELETE all photos filed in a given album
2015-09-29 18:19:54 -04:00
*/
2019-05-01 19:36:14 -04:00
if ( ! empty ( $_POST [ 'dropalbum' ])) {
2018-01-15 08:05:12 -05:00
$res = [];
2010-12-05 21:08:36 -05:00
// get the list of photos we are about to delete
2016-10-22 06:14:41 -04:00
if ( $visitor ) {
2010-12-05 21:08:36 -05:00
$r = q ( " SELECT distinct(`resource-id`) as `rid` FROM `photo` WHERE `contact-id` = %d AND `uid` = %d AND `album` = '%s' " ,
intval ( $visitor ),
intval ( $page_owner_uid ),
2018-07-21 09:10:13 -04:00
DBA :: escape ( $album )
2010-12-05 21:08:36 -05:00
);
2016-10-22 06:14:41 -04:00
} else {
2010-12-05 21:08:36 -05:00
$r = q ( " SELECT distinct(`resource-id`) as `rid` FROM `photo` WHERE `uid` = %d AND `album` = '%s' " ,
intval ( local_user ()),
2018-07-21 09:10:13 -04:00
DBA :: escape ( $album )
2010-12-05 21:08:36 -05:00
);
}
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $r )) {
2016-12-20 15:15:53 -05:00
foreach ( $r as $rr ) {
2018-11-21 10:28:09 -05:00
$res [] = $rr [ 'rid' ];
2010-08-08 20:08:39 -04:00
}
2010-12-05 21:08:36 -05:00
2019-05-01 19:36:14 -04:00
// remove the associated photos
Photo :: delete ([ 'resource-id' => $res , 'uid' => $page_owner_uid ]);
2010-12-05 21:08:36 -05:00
2019-05-01 19:36:14 -04:00
// find and delete the corresponding item with all the comments and likes/dislikes
Item :: deleteForUser ([ 'resource-id' => $res , 'uid' => $page_owner_uid ], $page_owner_uid );
2016-12-25 10:58:38 -05:00
2019-05-01 19:36:14 -04:00
// Update the photo albums cache
Photo :: clearAlbumCache ( $page_owner_uid );
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'Album successfully deleted' ));
2019-05-01 19:36:14 -04:00
} else {
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'Album was empty.' ));
2019-05-01 19:36:14 -04:00
}
2010-08-08 20:08:39 -04:00
}
2016-12-25 10:58:38 -05:00
2021-07-24 06:09:39 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . $user [ 'nickname' ] . '/album' );
2013-01-26 14:52:21 -05:00
}
2021-07-25 09:08:22 -04:00
if ( DI :: args () -> getArgc () > 3 && DI :: args () -> getArgv ()[ 2 ] === 'image' ) {
2019-05-01 19:36:14 -04:00
// Check if the user has responded to a delete confirmation query for a single photo
if ( ! empty ( $_POST [ 'canceled' ])) {
2021-07-25 09:08:22 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . DI :: args () -> getArgv ()[ 1 ] . '/image/' . DI :: args () -> getArgv ()[ 3 ]);
2013-01-26 14:52:21 -05:00
}
2019-05-01 19:36:14 -04:00
if ( ! empty ( $_POST [ 'delete' ])) {
// same as above but remove single photo
if ( $visitor ) {
2021-07-25 09:08:22 -04:00
$condition = [ 'contact-id' => $visitor , 'uid' => $page_owner_uid , 'resource-id' => DI :: args () -> getArgv ()[ 3 ]];
2019-05-02 09:49:20 -04:00
2019-05-01 19:36:14 -04:00
} else {
2021-07-25 09:08:22 -04:00
$condition = [ 'uid' => local_user (), 'resource-id' => DI :: args () -> getArgv ()[ 3 ]];
2019-05-01 19:36:14 -04:00
}
2018-07-22 21:19:28 -04:00
2019-05-02 09:49:20 -04:00
$photo = DBA :: selectFirst ( 'photo' , [ 'resource-id' ], $condition );
if ( DBA :: isResult ( $photo )) {
Photo :: delete ([ 'uid' => $page_owner_uid , 'resource-id' => $photo [ 'resource-id' ]]);
2010-08-08 20:08:39 -04:00
2019-05-02 09:49:20 -04:00
Item :: deleteForUser ([ 'resource-id' => $photo [ 'resource-id' ], 'uid' => $page_owner_uid ], $page_owner_uid );
2018-05-29 01:22:57 -04:00
2019-05-01 19:36:14 -04:00
// Update the photo albums cache
Photo :: clearAlbumCache ( $page_owner_uid );
} else {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Failed to delete the photo.' ));
2021-07-25 09:08:22 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . DI :: args () -> getArgv ()[ 1 ] . '/image/' . DI :: args () -> getArgv ()[ 3 ]);
2019-05-01 19:36:14 -04:00
}
2010-08-08 20:08:39 -04:00
2021-07-25 09:08:22 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . DI :: args () -> getArgv ()[ 1 ]);
2019-05-01 19:36:14 -04:00
return ; // NOTREACHED
}
2010-08-08 20:08:39 -04:00
}
2021-07-25 09:08:22 -04:00
if ( DI :: args () -> getArgc () > 2 && ( ! empty ( $_POST [ 'desc' ]) || ! empty ( $_POST [ 'newtag' ]) || isset ( $_POST [ 'albname' ]))) {
2018-11-09 13:29:42 -05:00
$desc = ! empty ( $_POST [ 'desc' ]) ? Strings :: escapeTags ( trim ( $_POST [ 'desc' ])) : '' ;
$rawtags = ! empty ( $_POST [ 'newtag' ]) ? Strings :: escapeTags ( trim ( $_POST [ 'newtag' ])) : '' ;
2018-11-30 09:06:22 -05:00
$item_id = ! empty ( $_POST [ 'item_id' ]) ? intval ( $_POST [ 'item_id' ]) : 0 ;
2020-04-21 22:14:11 -04:00
$albname = ! empty ( $_POST [ 'albname' ]) ? trim ( $_POST [ 'albname' ]) : '' ;
2018-11-09 13:29:42 -05:00
$origaname = ! empty ( $_POST [ 'origaname' ]) ? Strings :: escapeTags ( trim ( $_POST [ 'origaname' ])) : '' ;
2018-07-22 19:49:16 -04:00
2021-07-25 09:08:22 -04:00
$resource_id = DI :: args () -> getArgv ()[ 3 ];
2010-08-08 04:58:26 -04:00
2017-12-28 15:37:23 -05:00
if ( ! strlen ( $albname )) {
2018-01-26 21:38:34 -05:00
$albname = DateTimeFormat :: localNow ( 'Y' );
2017-03-25 09:56:23 -04:00
}
2012-05-23 04:01:04 -04:00
2018-07-22 21:19:28 -04:00
if ( ! empty ( $_POST [ 'rotate' ]) && ( intval ( $_POST [ 'rotate' ]) == 1 || intval ( $_POST [ 'rotate' ]) == 2 )) {
2018-10-29 17:20:46 -04:00
Logger :: log ( 'rotate' );
2012-05-23 04:01:04 -04:00
2018-11-21 11:55:16 -05:00
$photo = Photo :: getPhotoForUser ( $page_owner_uid , $resource_id );
2018-07-22 21:19:28 -04:00
2018-11-21 11:55:16 -05:00
if ( DBA :: isResult ( $photo )) {
$image = Photo :: getImageForPhoto ( $photo );
2018-07-22 21:19:28 -04:00
if ( $image -> isValid ()) {
2018-06-19 15:06:17 -04:00
$rotate_deg = (( intval ( $_POST [ 'rotate' ]) == 1 ) ? 270 : 90 );
2018-07-22 21:19:28 -04:00
$image -> rotate ( $rotate_deg );
2012-05-23 04:01:04 -04:00
2018-07-22 21:19:28 -04:00
$width = $image -> getWidth ();
$height = $image -> getHeight ();
2012-05-23 04:01:04 -04:00
2018-11-21 11:55:16 -05:00
Photo :: update ([ 'height' => $height , 'width' => $width ], [ 'resource-id' => $resource_id , 'uid' => $page_owner_uid , 'scale' => 0 ], $image );
2012-05-23 04:01:04 -04:00
2016-10-22 06:14:41 -04:00
if ( $width > 640 || $height > 640 ) {
2018-07-22 21:19:28 -04:00
$image -> scaleDown ( 640 );
$width = $image -> getWidth ();
$height = $image -> getHeight ();
2013-01-13 09:11:06 -05:00
2018-11-21 11:55:16 -05:00
Photo :: update ([ 'height' => $height , 'width' => $width ], [ 'resource-id' => $resource_id , 'uid' => $page_owner_uid , 'scale' => 1 ], $image );
2012-05-23 04:01:04 -04:00
}
2016-10-22 06:14:41 -04:00
if ( $width > 320 || $height > 320 ) {
2018-07-22 21:19:28 -04:00
$image -> scaleDown ( 320 );
$width = $image -> getWidth ();
$height = $image -> getHeight ();
2012-05-23 04:01:04 -04:00
2018-11-21 11:55:16 -05:00
Photo :: update ([ 'height' => $height , 'width' => $width ], [ 'resource-id' => $resource_id , 'uid' => $page_owner_uid , 'scale' => 2 ], $image );
2013-01-13 09:11:06 -05:00
}
2012-05-23 04:01:04 -04:00
}
}
}
2011-02-03 18:13:38 -05:00
2019-01-07 13:23:14 -05:00
$photos_stmt = DBA :: select ( 'photo' , [], [ 'resource-id' => $resource_id , 'uid' => $page_owner_uid ], [ 'order' => [ 'scale' => true ]]);
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2019-01-07 13:23:14 -05:00
$photos = DBA :: toArray ( $photos_stmt );
if ( DBA :: isResult ( $photos )) {
$photo = $photos [ 0 ];
2018-11-21 11:55:16 -05:00
$ext = $phototypes [ $photo [ 'type' ]];
Photo :: update (
[ 'desc' => $desc , 'album' => $albname , 'allow_cid' => $str_contact_allow , 'allow_gid' => $str_group_allow , 'deny_cid' => $str_contact_deny , 'deny_gid' => $str_group_deny ],
[ 'resource-id' => $resource_id , 'uid' => $page_owner_uid ]
2010-08-08 20:08:39 -04:00
);
2017-03-25 09:56:23 -04:00
2016-12-25 20:41:00 -05:00
// Update the photo albums cache if album name was changed
if ( $albname !== $origaname ) {
2018-01-03 22:36:15 -05:00
Photo :: clearAlbumCache ( $page_owner_uid );
2016-12-25 20:41:00 -05:00
}
2019-01-07 13:23:14 -05:00
/* Don't make the item visible if the only change was the album name */
2011-02-08 00:16:39 -05:00
2019-01-07 13:23:14 -05:00
$visibility = 0 ;
if ( $photo [ 'desc' ] !== $desc || strlen ( $rawtags )) {
$visibility = 1 ;
}
2017-03-25 09:56:23 -04:00
}
2014-07-21 18:36:20 -04:00
2019-01-07 13:23:14 -05:00
if ( DBA :: isResult ( $photos ) && ! $item_id ) {
2010-11-02 02:42:26 -04:00
// Create item container
2010-08-08 20:08:39 -04:00
$title = '' ;
2018-06-16 02:44:19 -04:00
$uri = Item :: newURI ( $page_owner_uid );
2014-07-21 18:36:20 -04:00
2018-01-15 08:05:12 -05:00
$arr = [];
2018-09-27 07:52:15 -04:00
$arr [ 'guid' ] = System :: createUUID ();
2010-12-05 21:08:36 -05:00
$arr [ 'uid' ] = $page_owner_uid ;
2010-11-03 22:47:07 -04:00
$arr [ 'uri' ] = $uri ;
2018-07-19 09:52:05 -04:00
$arr [ 'post-type' ] = Item :: PT_IMAGE ;
2010-11-03 22:47:07 -04:00
$arr [ 'wall' ] = 1 ;
2018-11-21 11:55:16 -05:00
$arr [ 'resource-id' ] = $photo [ 'resource-id' ];
2010-12-05 21:08:36 -05:00
$arr [ 'contact-id' ] = $owner_record [ 'id' ];
$arr [ 'owner-name' ] = $owner_record [ 'name' ];
$arr [ 'owner-link' ] = $owner_record [ 'url' ];
$arr [ 'owner-avatar' ] = $owner_record [ 'thumb' ];
$arr [ 'author-name' ] = $owner_record [ 'name' ];
$arr [ 'author-link' ] = $owner_record [ 'url' ];
$arr [ 'author-avatar' ] = $owner_record [ 'thumb' ];
2010-11-03 22:47:07 -04:00
$arr [ 'title' ] = $title ;
2018-11-21 11:55:16 -05:00
$arr [ 'allow_cid' ] = $photo [ 'allow_cid' ];
$arr [ 'allow_gid' ] = $photo [ 'allow_gid' ];
$arr [ 'deny_cid' ] = $photo [ 'deny_cid' ];
$arr [ 'deny_gid' ] = $photo [ 'deny_gid' ];
2011-02-08 00:16:39 -05:00
$arr [ 'visible' ] = $visibility ;
2011-10-17 17:52:03 -04:00
$arr [ 'origin' ] = 1 ;
2014-02-22 09:46:19 -05:00
2021-07-24 06:09:39 -04:00
$arr [ 'body' ] = '[url=' . DI :: baseUrl () . '/photos/' . $user [ 'nickname' ] . '/image/' . $photo [ 'resource-id' ] . ']'
2019-12-30 17:00:08 -05:00
. '[img]' . DI :: baseUrl () . '/photo/' . $photo [ 'resource-id' ] . '-' . $photo [ 'scale' ] . '.' . $ext . '[/img]'
2010-09-14 01:57:31 -04:00
. '[/url]' ;
2014-02-22 09:46:19 -05:00
2018-01-28 06:18:08 -05:00
$item_id = Item :: insert ( $arr );
2010-08-08 20:08:39 -04:00
}
2016-10-22 06:14:41 -04:00
if ( $item_id ) {
2021-07-30 02:22:52 -04:00
$item = Post :: selectFirst ([ 'inform' , 'uri-id' ], [ 'id' => $item_id , 'uid' => $page_owner_uid ]);
2019-05-26 09:00:19 -04:00
if ( DBA :: isResult ( $item )) {
$old_inform = $item [ 'inform' ];
}
2010-11-02 02:42:26 -04:00
}
2010-08-08 04:58:26 -04:00
2016-10-22 06:14:41 -04:00
if ( strlen ( $rawtags )) {
2010-11-02 02:42:26 -04:00
$inform = '' ;
// if the new tag doesn't have a namespace specifier (@foo or #foo) give it a hashtag
2018-01-01 16:47:00 -05:00
$x = substr ( $rawtags , 0 , 1 );
2017-03-25 09:56:23 -04:00
if ( $x !== '@' && $x !== '#' ) {
2010-11-02 02:42:26 -04:00
$rawtags = '#' . $rawtags ;
2017-03-25 09:56:23 -04:00
}
2010-11-02 02:42:26 -04:00
2018-01-15 08:05:12 -05:00
$taginfo = [];
2018-11-09 13:24:19 -05:00
$tags = BBCode :: getTags ( $rawtags );
2010-11-02 02:42:26 -04:00
2016-10-22 06:14:41 -04:00
if ( count ( $tags )) {
foreach ( $tags as $tag ) {
2017-03-30 14:33:38 -04:00
if ( strpos ( $tag , '@' ) === 0 ) {
2018-01-01 16:47:00 -05:00
$profile = '' ;
2019-05-02 09:49:20 -04:00
$contact = null ;
2010-11-02 02:42:26 -04:00
$name = substr ( $tag , 1 );
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2017-03-30 14:33:38 -04:00
if (( strpos ( $name , '@' )) || ( strpos ( $name , 'http://' ))) {
2010-11-02 02:42:26 -04:00
$newname = $name ;
2016-07-09 14:09:09 -04:00
$links = @ Probe :: lrdd ( $name );
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2016-10-22 06:14:41 -04:00
if ( count ( $links )) {
foreach ( $links as $link ) {
2017-03-25 09:56:23 -04:00
if ( $link [ '@attributes' ][ 'rel' ] === 'http://webfinger.net/rel/profile-page' ) {
2015-09-29 18:19:54 -04:00
$profile = $link [ '@attributes' ][ 'href' ];
2017-03-25 09:56:23 -04:00
}
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2016-10-22 06:14:41 -04:00
if ( $link [ '@attributes' ][ 'rel' ] === 'salmon' ) {
2017-03-30 14:33:38 -04:00
$salmon = '$url:' . str_replace ( ',' , '%sc' , $link [ '@attributes' ][ 'href' ]);
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2017-03-25 09:56:23 -04:00
if ( strlen ( $inform )) {
2010-11-02 02:42:26 -04:00
$inform .= ',' ;
2017-03-25 09:56:23 -04:00
}
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2017-03-25 09:56:23 -04:00
$inform .= $salmon ;
2010-11-02 02:42:26 -04:00
}
}
}
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2018-01-15 08:05:12 -05:00
$taginfo [] = [ $newname , $profile , $salmon ];
2016-10-22 06:14:41 -04:00
} else {
2010-11-02 02:42:26 -04:00
$newname = $name ;
2011-10-27 22:12:30 -04:00
$tagcid = 0 ;
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2017-03-30 14:33:38 -04:00
if ( strrpos ( $newname , '+' )) {
$tagcid = intval ( substr ( $newname , strrpos ( $newname , '+' ) + 1 ));
2017-03-25 09:56:23 -04:00
}
2011-10-27 22:12:30 -04:00
2016-10-22 06:14:41 -04:00
if ( $tagcid ) {
2019-05-02 09:49:20 -04:00
$contact = DBA :: selectFirst ( 'contact' , [], [ 'id' => $tagcid , 'uid' => $page_owner_uid ]);
2016-10-22 06:14:41 -04:00
} else {
2012-09-29 19:55:40 -04:00
$newname = str_replace ( '_' , ' ' , $name );
//select someone from this user's contacts by name
2019-05-02 09:49:20 -04:00
$contact = DBA :: selectFirst ( 'contact' , [], [ 'name' => $newname , 'uid' => $page_owner_uid ]);
if ( ! DBA :: isResult ( $contact )) {
2012-09-29 19:55:40 -04:00
//select someone by attag or nick and the name passed in
2019-05-02 09:49:20 -04:00
$contact = DBA :: selectFirst ( 'contact' , [],
[ '(`attag` = ? OR `nick` = ?) AND `uid` = ?' , $name , $name , $page_owner_uid ],
[ 'order' => [ 'attag' => true ]]
2012-09-29 19:55:40 -04:00
);
}
}
2017-03-30 15:38:22 -04:00
2019-05-02 09:49:20 -04:00
if ( DBA :: isResult ( $contact )) {
$newname = $contact [ 'name' ];
$profile = $contact [ 'url' ];
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2019-05-02 09:49:20 -04:00
$notify = 'cid:' . $contact [ 'id' ];
2017-03-25 09:56:23 -04:00
if ( strlen ( $inform )) {
2010-11-02 02:42:26 -04:00
$inform .= ',' ;
2017-03-25 09:56:23 -04:00
}
2010-11-03 19:48:21 -04:00
$inform .= $notify ;
2010-11-02 02:42:26 -04:00
}
}
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2016-10-22 06:14:41 -04:00
if ( $profile ) {
2019-05-02 09:49:20 -04:00
if ( ! empty ( $contact )) {
2020-05-13 22:35:13 -04:00
$taginfo [] = [ $newname , $profile , $notify , $contact ];
2017-03-25 09:56:23 -04:00
} else {
2020-05-13 22:35:13 -04:00
$taginfo [] = [ $newname , $profile , $notify , null ];
2017-03-25 09:56:23 -04:00
}
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2017-03-25 09:56:23 -04:00
$profile = str_replace ( ',' , '%2c' , $profile );
2020-04-18 16:46:41 -04:00
if ( ! empty ( $item [ 'uri-id' ])) {
Tag :: store ( $item [ 'uri-id' ], Tag :: MENTION , $newname , $profile );
2021-07-24 06:09:39 -04:00
}
2010-11-02 02:42:26 -04:00
}
2017-03-30 14:33:38 -04:00
} elseif ( strpos ( $tag , '#' ) === 0 ) {
2014-07-21 18:36:20 -04:00
$tagname = substr ( $tag , 1 );
2020-04-18 16:46:41 -04:00
if ( ! empty ( $item [ 'uri-id' ])) {
Tag :: store ( $item [ 'uri-id' ], Tag :: HASHTAG , $tagname );
}
2010-11-02 02:42:26 -04:00
}
}
}
2019-05-26 09:00:19 -04:00
$newinform = $old_inform ? ? '' ;
2017-03-25 09:56:23 -04:00
if ( strlen ( $newinform ) && strlen ( $inform )) {
2010-11-02 02:42:26 -04:00
$newinform .= ',' ;
2017-03-25 09:56:23 -04:00
}
2010-11-02 02:42:26 -04:00
$newinform .= $inform ;
2020-05-05 01:11:59 -04:00
$fields = [ 'inform' => $newinform , 'edited' => DateTimeFormat :: utcNow (), 'changed' => DateTimeFormat :: utcNow ()];
2018-02-06 07:40:22 -05:00
$condition = [ 'id' => $item_id ];
Item :: update ( $fields , $condition );
2010-11-03 19:48:21 -04:00
2010-11-04 23:47:44 -04:00
$best = 0 ;
2019-01-07 13:23:14 -05:00
foreach ( $photos as $scales ) {
2016-10-22 06:14:41 -04:00
if ( intval ( $scales [ 'scale' ]) == 2 ) {
2010-11-04 23:47:44 -04:00
$best = 2 ;
break ;
}
Cleanups: isResult() more used, readability improved (#5608)
* [diaspora]: Maybe SimpleXMLElement is the right type-hint?
* Changes proposed + pre-renaming:
- pre-renamed $db -> $connection
- added TODOs for not allowing bad method invocations (there is a
BadMethodCallException in SPL)
* If no record is found, below $r[0] will fail with a E_NOTICE and the code
doesn't behave as expected.
* Ops, one more left ...
* Continued:
- added documentation for Contact::updateSslPolicy() method
- added type-hint for $contact of same method
- empty lines added + TODO where the bug origins that $item has no element 'body'
* Added empty lines for better readability
* Cleaned up:
- no more x() (deprecated) usage but empty() instead
- fixed mixing of space/tab indending
- merged else/if block goether in elseif() (lesser nested code blocks)
* Re-fixed DBM -> DBA switch
* Fixes/rewrites:
- use empty()/isset() instead of deprecated x()
- merged 2 nested if() blocks into one
- avoided nested if() block inside else block by rewriting it to elseif()
- $contact_id is an integer, let's test on > 0 here
- added a lot spaces and some empty lines for better readability
* Rewrite:
- moved all CONTACT_* constants from boot.php to Contact class
* CR request:
- renamed Contact::CONTACT_IS_* -> Contact::* ;-)
* Rewrites:
- moved PAGE_* to Friendica\Model\Profile class
- fixed mixure with "Contact::* rewrite"
* Ops, one still there (return is no function)
* Rewrite to Proxy class:
- introduced new Friendica\Network\Proxy class for in exchange of proxy_*()
functions
- moved also all PROXY_* constants there as Proxy::*
- removed now no longer needed mod/proxy.php loading as composer's auto-load
will do this for us
- renamed those proxy_*() functions to better names:
+ proxy_init() -> Proxy::init() (public)
+ proxy_url() -> Proxy::proxifyUrl() (public)
+ proxy_parse_html() -> Proxy::proxifyHtml() (public)
+ proxy_is_local_image() -> Proxy::isLocalImage() (private)
+ proxy_parse_query() -> Proxy::parseQuery() (private)
+ proxy_img_cb() -> Proxy::replaceUrl() (private)
* CR request:
- moved all PAGE_* constants to Friendica\Model\Contact class
- fixed all references of both classes
* Ops, need to set $a here ...
* CR request:
- moved Proxy class to Friendica\Module
- extended BaseModule
* Ops, no need for own instance of $a when self::getApp() is around.
* Proxy-rewrite:
- proxy_url() and proxy_parse_html() are both non-module functions (now
methods)
- so they must be splitted into a seperate class
- also the SIZE_* and DEFAULT_TIME constants are both not relevant to module
* No instances from utility classes
* Fixed error:
- proxify*() is now located in `Friendica\Util\ProxyUtils`
* Moved back to original place, ops? How did they move here? Well, it was not
intended by me.
* Removed duplicate (left-over from split) constants and static array. Thank to
MrPetovan finding it.
* Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
* Rewrite:
- stopped using deprecated NETWORK_* constants, now Protocol::* should be used
- still left them intact for slow/lazy developers ...
* Ops, was added accidentally ...
* Ops, why these wrong moves?
* Ops, one to much (thanks to MrPetovan)
* Ops, wrong moving ...
* moved back to original place ...
* spaces added
* empty lines add for better readability.
* convertered spaces -> tab for code indenting.
* CR request: Add space between if and brace.
* CR requests fixed + move reverted
- ops, src/Module/*.php has been moved to src/Network/ accidentally
- reverted some parts in src/Database/DBA.php as pointed out by Annando
- removed internal TODO items
- added some spaces for better readability
2018-08-24 01:05:49 -04:00
2016-10-22 06:14:41 -04:00
if ( intval ( $scales [ 'scale' ]) == 4 ) {
2010-11-04 23:47:44 -04:00
$best = 4 ;
break ;
2010-11-03 19:48:21 -04:00
}
}
2016-10-22 06:14:41 -04:00
if ( count ( $taginfo )) {
foreach ( $taginfo as $tagged ) {
2018-06-16 02:44:19 -04:00
$uri = Item :: newURI ( $page_owner_uid );
2010-11-04 23:47:44 -04:00
2018-01-15 08:05:12 -05:00
$arr = [];
2018-09-27 07:52:15 -04:00
$arr [ 'guid' ] = System :: createUUID ();
2010-12-05 21:08:36 -05:00
$arr [ 'uid' ] = $page_owner_uid ;
2010-11-04 23:47:44 -04:00
$arr [ 'uri' ] = $uri ;
$arr [ 'wall' ] = 1 ;
2010-12-05 21:08:36 -05:00
$arr [ 'contact-id' ] = $owner_record [ 'id' ];
$arr [ 'owner-name' ] = $owner_record [ 'name' ];
$arr [ 'owner-link' ] = $owner_record [ 'url' ];
$arr [ 'owner-avatar' ] = $owner_record [ 'thumb' ];
$arr [ 'author-name' ] = $owner_record [ 'name' ];
$arr [ 'author-link' ] = $owner_record [ 'url' ];
$arr [ 'author-avatar' ] = $owner_record [ 'thumb' ];
2010-11-04 23:47:44 -04:00
$arr [ 'title' ] = '' ;
2018-11-21 11:55:16 -05:00
$arr [ 'allow_cid' ] = $photo [ 'allow_cid' ];
$arr [ 'allow_gid' ] = $photo [ 'allow_gid' ];
$arr [ 'deny_cid' ] = $photo [ 'deny_cid' ];
$arr [ 'deny_gid' ] = $photo [ 'deny_gid' ];
2010-11-04 23:47:44 -04:00
$arr [ 'visible' ] = 1 ;
2019-10-23 18:25:43 -04:00
$arr [ 'verb' ] = Activity :: TAG ;
2018-06-27 23:31:10 -04:00
$arr [ 'gravity' ] = GRAVITY_PARENT ;
2019-10-24 18:10:20 -04:00
$arr [ 'object-type' ] = Activity\ObjectType :: PERSON ;
$arr [ 'target-type' ] = Activity\ObjectType :: IMAGE ;
2010-11-04 23:47:44 -04:00
$arr [ 'inform' ] = $tagged [ 2 ];
2011-10-17 17:52:03 -04:00
$arr [ 'origin' ] = 1 ;
2020-01-18 14:52:34 -05:00
$arr [ 'body' ] = DI :: l10n () -> t ( '%1$s was tagged in %2$s by %3$s' , '[url=' . $tagged [ 1 ] . ']' . $tagged [ 0 ] . '[/url]' , '[url=' . DI :: baseUrl () . '/photos/' . $owner_record [ 'nickname' ] . '/image/' . $photo [ 'resource-id' ] . ']' . DI :: l10n () -> t ( 'a photo' ) . '[/url]' , '[url=' . $owner_record [ 'url' ] . ']' . $owner_record [ 'name' ] . '[/url]' ) ;
2019-12-30 17:00:08 -05:00
$arr [ 'body' ] .= " \n \n " . '[url=' . DI :: baseUrl () . '/photos/' . $owner_record [ 'nickname' ] . '/image/' . $photo [ 'resource-id' ] . ']' . '[img]' . DI :: baseUrl () . " /photo/ " . $photo [ 'resource-id' ] . '-' . $best . '.' . $ext . '[/img][/url]' . " \n " ;
2010-11-04 23:47:44 -04:00
2019-10-24 18:10:20 -04:00
$arr [ 'object' ] = '<object><type>' . Activity\ObjectType :: PERSON . '</type><title>' . $tagged [ 0 ] . '</title><id>' . $tagged [ 1 ] . '/' . $tagged [ 0 ] . '</id>' ;
2018-11-05 07:40:18 -05:00
$arr [ 'object' ] .= '<link>' . XML :: escape ( '<link rel="alternate" type="text/html" href="' . $tagged [ 1 ] . '" />' . " \n " );
2017-03-25 09:56:23 -04:00
if ( $tagged [ 3 ]) {
2019-01-07 13:23:14 -05:00
$arr [ 'object' ] .= XML :: escape ( '<link rel="photo" type="' . $photo [ 'type' ] . '" href="' . $tagged [ 3 ][ 'photo' ] . '" />' . " \n " );
2017-03-25 09:56:23 -04:00
}
2010-11-04 23:47:44 -04:00
$arr [ 'object' ] .= '</link></object>' . " \n " ;
2019-10-24 18:10:20 -04:00
$arr [ 'target' ] = '<target><type>' . Activity\ObjectType :: IMAGE . '</type><title>' . $photo [ 'desc' ] . '</title><id>'
2019-12-30 17:00:08 -05:00
. DI :: baseUrl () . '/photos/' . $owner_record [ 'nickname' ] . '/image/' . $photo [ 'resource-id' ] . '</id>' ;
$arr [ 'target' ] .= '<link>' . XML :: escape ( '<link rel="alternate" type="text/html" href="' . DI :: baseUrl () . '/photos/' . $owner_record [ 'nickname' ] . '/image/' . $photo [ 'resource-id' ] . '" />' . " \n " . '<link rel="preview" type="' . $photo [ 'type' ] . '" href="' . DI :: baseUrl () . " /photo/ " . $photo [ 'resource-id' ] . '-' . $best . '.' . $ext . '" />' ) . '</link></target>' ;
2010-11-04 23:47:44 -04:00
2019-01-07 01:23:49 -05:00
Item :: insert ( $arr );
2010-11-04 23:47:44 -04:00
}
}
2010-11-02 02:42:26 -04:00
}
2019-12-15 18:28:31 -05:00
DI :: baseUrl () -> redirect ( $_SESSION [ 'photo_return' ]);
2010-08-08 04:58:26 -04:00
return ; // NOTREACHED
}
2018-01-01 16:47:00 -05:00
// default post action - upload a photo
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_post_init' , $_POST );
2011-01-27 06:52:18 -05:00
2018-01-01 16:47:00 -05:00
// Determine the album to use
2020-04-21 22:14:11 -04:00
$album = trim ( $_REQUEST [ 'album' ] ? ? '' );
$newalbum = trim ( $_REQUEST [ 'newalbum' ] ? ? '' );
2010-08-06 00:15:24 -04:00
2020-04-21 22:14:11 -04:00
Logger :: info ( 'album= ' . $album . ' newalbum= ' . $newalbum );
2010-08-06 00:15:24 -04:00
2017-12-28 15:37:23 -05:00
if ( ! strlen ( $album )) {
2017-03-25 09:56:23 -04:00
if ( strlen ( $newalbum )) {
2010-08-06 00:15:24 -04:00
$album = $newalbum ;
2017-03-25 09:56:23 -04:00
} else {
2018-01-26 21:38:34 -05:00
$album = DateTimeFormat :: localNow ( 'Y' );
2017-03-25 09:56:23 -04:00
}
2010-08-06 00:15:24 -04:00
}
2017-03-25 09:56:23 -04:00
/*
2011-01-27 21:45:19 -05:00
* We create a wall item for every photo , but we don ' t want to
* overwhelm the data stream with a hundred newly uploaded photos .
2011-06-07 19:23:37 -04:00
* So we will make the first photo uploaded to this album in the last several hours
2011-01-27 21:45:19 -05:00
* visible by default , the rest will become visible over time when and if
2015-06-22 14:07:19 -04:00
* they acquire comments , likes , dislikes , and / or tags
2011-01-27 21:45:19 -05:00
*/
2019-07-29 13:38:55 -04:00
$r = Photo :: selectToArray ([], [ '`album` = ? AND `uid` = ? AND `created` > UTC_TIMESTAMP() - INTERVAL 3 HOUR' , $album , $page_owner_uid ]);
2018-07-22 19:49:16 -04:00
2020-01-18 14:52:34 -05:00
if ( ! DBA :: isResult ( $r ) || ( $album == DI :: l10n () -> t ( 'Profile Photos' ))) {
2010-08-08 20:08:39 -04:00
$visible = 1 ;
2017-03-25 09:56:23 -04:00
} else {
2010-11-03 22:47:07 -04:00
$visible = 0 ;
2017-03-25 09:56:23 -04:00
}
2015-06-22 14:07:19 -04:00
2018-07-22 19:49:16 -04:00
if ( ! empty ( $_REQUEST [ 'not_visible' ]) && $_REQUEST [ 'not_visible' ] !== 'false' ) {
2011-10-01 05:22:48 -04:00
$visible = 0 ;
2017-03-25 09:56:23 -04:00
}
2011-10-01 05:22:48 -04:00
2018-01-15 08:05:12 -05:00
$ret = [ 'src' => '' , 'filename' => '' , 'filesize' => 0 , 'type' => '' ];
2010-08-07 09:20:27 -04:00
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_post_file' , $ret );
2010-08-07 09:20:27 -04:00
2018-07-22 21:19:28 -04:00
if ( ! empty ( $ret [ 'src' ]) && ! empty ( $ret [ 'filesize' ])) {
2011-01-27 21:45:19 -05:00
$src = $ret [ 'src' ];
$filename = $ret [ 'filename' ];
$filesize = $ret [ 'filesize' ];
2012-06-07 11:42:13 -04:00
$type = $ret [ 'type' ];
2018-01-01 16:47:00 -05:00
$error = UPLOAD_ERR_OK ;
2018-09-11 00:10:11 -04:00
} elseif ( ! empty ( $_FILES [ 'userfile' ])) {
2018-01-01 16:47:00 -05:00
$src = $_FILES [ 'userfile' ][ 'tmp_name' ];
$filename = basename ( $_FILES [ 'userfile' ][ 'name' ]);
$filesize = intval ( $_FILES [ 'userfile' ][ 'size' ]);
$type = $_FILES [ 'userfile' ][ 'type' ];
$error = $_FILES [ 'userfile' ][ 'error' ];
2018-09-11 00:10:11 -04:00
} else {
$error = UPLOAD_ERR_NO_FILE ;
2011-01-27 21:45:19 -05:00
}
2018-01-01 16:47:00 -05:00
if ( $error !== UPLOAD_ERR_OK ) {
switch ( $error ) {
case UPLOAD_ERR_INI_SIZE :
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Image exceeds size limit of %s' , ini_get ( 'upload_max_filesize' )));
2018-01-01 16:47:00 -05:00
break ;
case UPLOAD_ERR_FORM_SIZE :
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Image exceeds size limit of %s' , Strings :: formatBytes ( $_REQUEST [ 'MAX_FILE_SIZE' ] ? ? 0 )));
2018-01-01 16:47:00 -05:00
break ;
case UPLOAD_ERR_PARTIAL :
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Image upload didn\'t complete, please try again' ));
2018-01-01 16:47:00 -05:00
break ;
case UPLOAD_ERR_NO_FILE :
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Image file is missing' ));
2018-01-01 16:47:00 -05:00
break ;
case UPLOAD_ERR_NO_TMP_DIR :
case UPLOAD_ERR_CANT_WRITE :
case UPLOAD_ERR_EXTENSION :
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Server can\'t accept new file upload at this time, please contact your administrator' ));
2018-01-01 16:47:00 -05:00
break ;
}
@ unlink ( $src );
$foo = 0 ;
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_post_end' , $foo );
2018-01-01 16:47:00 -05:00
return ;
}
2020-04-01 01:42:44 -04:00
$type = Images :: getMimeTypeBySource ( $src , $filename , $type );
2010-08-06 00:15:24 -04:00
2018-10-30 09:58:45 -04:00
Logger :: log ( 'photos: upload: received file: ' . $filename . ' as ' . $src . ' (' . $type . ') ' . $filesize . ' bytes' , Logger :: DEBUG );
2011-06-28 21:59:41 -04:00
2020-01-19 15:21:13 -05:00
$maximagesize = DI :: config () -> get ( 'system' , 'maximagesize' );
2010-11-09 21:24:35 -05:00
2017-12-28 15:37:23 -05:00
if ( $maximagesize && ( $filesize > $maximagesize )) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Image exceeds size limit of %s' , Strings :: formatBytes ( $maximagesize )));
2010-11-09 21:24:35 -05:00
@ unlink ( $src );
2011-05-21 20:17:27 -04:00
$foo = 0 ;
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_post_end' , $foo );
2010-11-09 21:24:35 -05:00
return ;
}
2017-12-28 15:37:23 -05:00
if ( ! $filesize ) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Image file is empty.' ));
2011-06-28 21:59:41 -04:00
@ unlink ( $src );
$foo = 0 ;
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_post_end' , $foo );
2011-06-28 21:59:41 -04:00
return ;
}
2018-10-30 09:58:45 -04:00
Logger :: log ( 'mod/photos.php: photos_post(): loading the contents of ' . $src , Logger :: DEBUG );
2011-01-27 21:45:19 -05:00
2010-08-06 00:15:24 -04:00
$imagedata = @ file_get_contents ( $src );
2012-06-25 04:37:44 -04:00
2018-07-22 21:19:28 -04:00
$image = new Image ( $imagedata , $type );
2010-08-06 00:15:24 -04:00
2018-07-22 21:19:28 -04:00
if ( ! $image -> isValid ()) {
2018-10-30 09:58:45 -04:00
Logger :: log ( 'mod/photos.php: photos_post(): unable to process image' , Logger :: DEBUG );
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Unable to process image.' ));
2010-08-06 00:15:24 -04:00
@ unlink ( $src );
2011-05-21 20:17:27 -04:00
$foo = 0 ;
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_post_end' , $foo );
2019-05-26 09:00:19 -04:00
return ;
2010-08-06 00:15:24 -04:00
}
2018-07-22 21:19:28 -04:00
$exif = $image -> orient ( $src );
2010-08-06 00:15:24 -04:00
@ unlink ( $src );
2020-01-19 15:21:13 -05:00
$max_length = DI :: config () -> get ( 'system' , 'max_image_length' );
2017-12-28 15:37:23 -05:00
if ( ! $max_length ) {
2012-06-28 12:33:21 -04:00
$max_length = MAX_IMAGE_LENGTH ;
2017-03-25 09:56:23 -04:00
}
if ( $max_length > 0 ) {
2018-07-22 21:19:28 -04:00
$image -> scaleDown ( $max_length );
2017-03-25 09:56:23 -04:00
}
2012-06-28 12:33:21 -04:00
2018-07-22 21:19:28 -04:00
$width = $image -> getWidth ();
$height = $image -> getHeight ();
2010-08-06 00:15:24 -04:00
$smallest = 0 ;
2019-10-26 09:05:35 -04:00
$resource_id = Photo :: newResource ();
2010-09-14 01:57:31 -04:00
2019-10-26 09:05:35 -04:00
$r = Photo :: store ( $image , $page_owner_uid , $visitor , $resource_id , $filename , $album , 0 , 0 , $str_contact_allow , $str_group_allow , $str_contact_deny , $str_group_deny );
2010-08-06 00:15:24 -04:00
2017-12-28 15:37:23 -05:00
if ( ! $r ) {
2018-10-30 09:58:45 -04:00
Logger :: log ( 'mod/photos.php: photos_post(): image store failed' , Logger :: DEBUG );
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Image upload failed.' ));
2019-05-26 09:00:19 -04:00
return ;
2010-08-06 00:15:24 -04:00
}
2016-10-22 06:14:41 -04:00
if ( $width > 640 || $height > 640 ) {
2018-07-22 21:19:28 -04:00
$image -> scaleDown ( 640 );
2019-10-26 09:05:35 -04:00
Photo :: store ( $image , $page_owner_uid , $visitor , $resource_id , $filename , $album , 1 , 0 , $str_contact_allow , $str_group_allow , $str_contact_deny , $str_group_deny );
2010-08-06 00:15:24 -04:00
$smallest = 1 ;
}
2016-10-22 06:14:41 -04:00
if ( $width > 320 || $height > 320 ) {
2018-07-22 21:19:28 -04:00
$image -> scaleDown ( 320 );
2019-10-26 09:05:35 -04:00
Photo :: store ( $image , $page_owner_uid , $visitor , $resource_id , $filename , $album , 2 , 0 , $str_contact_allow , $str_group_allow , $str_contact_deny , $str_group_deny );
2010-08-06 00:15:24 -04:00
$smallest = 2 ;
}
2015-06-22 14:07:19 -04:00
2018-06-16 02:44:19 -04:00
$uri = Item :: newURI ( $page_owner_uid );
2010-08-06 00:15:24 -04:00
// Create item container
2015-09-29 18:19:54 -04:00
$lat = $lon = null ;
2020-07-09 15:03:14 -04:00
if ( ! empty ( $exif [ 'GPS' ]) && Feature :: isEnabled ( $page_owner_uid , 'photo_location' )) {
2018-01-03 21:01:41 -05:00
$lat = Photo :: getGps ( $exif [ 'GPS' ][ 'GPSLatitude' ], $exif [ 'GPS' ][ 'GPSLatitudeRef' ]);
$lon = Photo :: getGps ( $exif [ 'GPS' ][ 'GPSLongitude' ], $exif [ 'GPS' ][ 'GPSLongitudeRef' ]);
2015-09-29 18:19:54 -04:00
}
2018-01-15 08:05:12 -05:00
$arr = [];
2017-03-25 09:56:23 -04:00
if ( $lat && $lon ) {
2015-09-29 18:19:54 -04:00
$arr [ 'coord' ] = $lat . ' ' . $lon ;
2017-03-25 09:56:23 -04:00
}
2015-09-29 18:19:54 -04:00
2018-09-27 07:52:15 -04:00
$arr [ 'guid' ] = System :: createUUID ();
2010-12-05 21:08:36 -05:00
$arr [ 'uid' ] = $page_owner_uid ;
2010-11-03 22:47:07 -04:00
$arr [ 'uri' ] = $uri ;
2021-04-01 00:58:53 -04:00
$arr [ 'post-type' ] = Item :: PT_IMAGE ;
2010-11-03 22:47:07 -04:00
$arr [ 'wall' ] = 1 ;
2019-10-26 09:05:35 -04:00
$arr [ 'resource-id' ] = $resource_id ;
2010-12-05 21:08:36 -05:00
$arr [ 'contact-id' ] = $owner_record [ 'id' ];
$arr [ 'owner-name' ] = $owner_record [ 'name' ];
$arr [ 'owner-link' ] = $owner_record [ 'url' ];
$arr [ 'owner-avatar' ] = $owner_record [ 'thumb' ];
$arr [ 'author-name' ] = $owner_record [ 'name' ];
$arr [ 'author-link' ] = $owner_record [ 'url' ];
$arr [ 'author-avatar' ] = $owner_record [ 'thumb' ];
2010-11-03 22:47:07 -04:00
$arr [ 'title' ] = '' ;
$arr [ 'allow_cid' ] = $str_contact_allow ;
$arr [ 'allow_gid' ] = $str_group_allow ;
$arr [ 'deny_cid' ] = $str_contact_deny ;
$arr [ 'deny_gid' ] = $str_group_deny ;
$arr [ 'visible' ] = $visible ;
2011-10-17 17:52:03 -04:00
$arr [ 'origin' ] = 1 ;
2019-12-30 17:00:08 -05:00
$arr [ 'body' ] = '[url=' . DI :: baseUrl () . '/photos/' . $owner_record [ 'nickname' ] . '/image/' . $resource_id . ']'
. '[img]' . DI :: baseUrl () . " /photo/ { $resource_id } - { $smallest } . " . $image -> getExt () . '[/img]'
2010-09-14 01:57:31 -04:00
. '[/url]' ;
2010-08-06 00:15:24 -04:00
2018-01-28 06:18:08 -05:00
$item_id = Item :: insert ( $arr );
2016-12-25 10:58:38 -05:00
// Update the photo albums cache
2018-01-03 22:36:15 -05:00
Photo :: clearAlbumCache ( $page_owner_uid );
2010-08-06 00:15:24 -04:00
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_post_end' , $item_id );
2010-08-06 00:15:24 -04:00
2020-01-04 17:43:13 -05:00
// addon uploaders should call "exit()" within the photo_post_end hook
2018-01-01 16:47:00 -05:00
// if they do not wish to be redirected
2010-08-06 00:15:24 -04:00
2019-12-15 18:28:31 -05:00
DI :: baseUrl () -> redirect ( $_SESSION [ 'photo_return' ]);
2011-01-27 21:45:19 -05:00
// NOTREACHED
2010-08-06 00:15:24 -04:00
}
2018-01-01 16:47:00 -05:00
function photos_content ( App $a )
{
2010-08-06 00:15:24 -04:00
// URLs:
// photos/name
// photos/name/upload
2012-01-15 20:48:42 -05:00
// photos/name/upload/xxxxx (xxxxx is album name)
2010-08-06 00:15:24 -04:00
// photos/name/album/xxxxx
// photos/name/album/xxxxx/edit
2019-05-01 19:36:14 -04:00
// photos/name/album/xxxxx/drop
2010-08-06 00:15:24 -04:00
// photos/name/image/xxxxx
// photos/name/image/xxxxx/edit
2019-05-01 19:36:14 -04:00
// photos/name/image/xxxxx/drop
2010-08-08 20:08:39 -04:00
2021-07-25 09:08:22 -04:00
$user = User :: getByNickname ( DI :: args () -> getArgv ()[ 1 ]);
2021-07-24 06:09:39 -04:00
if ( ! DBA :: isResult ( $user )) {
throw new HTTPException\NotFoundException ( DI :: l10n () -> t ( 'User not found.' ));
}
2020-01-19 15:21:13 -05:00
if ( DI :: config () -> get ( 'system' , 'block_public' ) && ! Session :: isAuthenticated ()) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Public access denied.' ));
2011-04-21 20:29:47 -04:00
return ;
}
2014-02-22 09:46:19 -05:00
2021-07-24 06:09:39 -04:00
if ( empty ( $user )) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'No photos selected' ));
2010-08-06 00:15:24 -04:00
return ;
}
2021-08-08 06:14:56 -04:00
$profile = Profile :: getByUID ( $user [ 'uid' ]);
2019-10-17 21:26:15 -04:00
$phototypes = Images :: supportedTypes ();
2012-06-07 11:42:13 -04:00
2019-12-15 19:33:13 -05:00
$_SESSION [ 'photo_return' ] = DI :: args () -> getCommand ();
2010-08-06 00:15:24 -04:00
2015-06-22 14:07:19 -04:00
// Parse arguments
2018-01-01 16:47:00 -05:00
$datum = null ;
2021-07-25 09:08:22 -04:00
if ( DI :: args () -> getArgc () > 3 ) {
$datatype = DI :: args () -> getArgv ()[ 2 ];
$datum = DI :: args () -> getArgv ()[ 3 ];
} elseif (( DI :: args () -> getArgc () > 2 ) && ( DI :: args () -> getArgv ()[ 2 ] === 'upload' )) {
2010-08-06 00:15:24 -04:00
$datatype = 'upload' ;
2017-03-25 09:56:23 -04:00
} else {
2010-08-06 00:15:24 -04:00
$datatype = 'summary' ;
2017-03-25 09:56:23 -04:00
}
2010-08-06 00:15:24 -04:00
2021-07-25 09:08:22 -04:00
if ( DI :: args () -> getArgc () > 4 ) {
$cmd = DI :: args () -> getArgv ()[ 4 ];
2017-03-25 09:56:23 -04:00
} else {
2010-08-06 00:15:24 -04:00
$cmd = 'view' ;
2017-03-25 09:56:23 -04:00
}
2010-08-06 00:15:24 -04:00
// Setup permissions structures
2016-01-04 05:46:19 -05:00
$can_post = false ;
$visitor = 0 ;
$contact = null ;
$remote_contact = false ;
$contact_id = 0 ;
2019-05-01 19:36:14 -04:00
$edit = '' ;
$drop = '' ;
2010-08-06 00:15:24 -04:00
2021-07-24 06:09:39 -04:00
$owner_uid = $user [ 'uid' ];
2010-09-27 22:48:45 -04:00
2021-07-24 06:09:39 -04:00
$community_page = (( $user [ 'page-flags' ] == User :: PAGE_FLAGS_COMMUNITY ) ? true : false );
2010-12-07 20:16:05 -05:00
2017-12-28 15:37:23 -05:00
if ( local_user () && ( local_user () == $owner_uid )) {
2016-01-04 05:46:19 -05:00
$can_post = true ;
2019-09-28 05:59:08 -04:00
} elseif ( $community_page && ! empty ( Session :: getRemoteContactID ( $owner_uid ))) {
$contact_id = Session :: getRemoteContactID ( $owner_uid );
2019-09-25 18:24:17 -04:00
$contact = DBA :: selectFirst ( 'contact' , [], [ 'id' => $contact_id , 'uid' => $owner_uid , 'blocked' => false , 'pending' => false ]);
2019-05-02 09:49:20 -04:00
2019-09-25 18:24:17 -04:00
if ( DBA :: isResult ( $contact )) {
$can_post = true ;
$remote_contact = true ;
$visitor = $contact_id ;
2016-01-04 05:46:19 -05:00
}
}
2018-01-01 16:47:00 -05:00
// perhaps they're visiting - but not a community page, so they wouldn't have write access
2019-09-28 05:59:08 -04:00
if ( ! empty ( Session :: getRemoteContactID ( $owner_uid )) && ! $visitor ) {
$contact_id = Session :: getRemoteContactID ( $owner_uid );
2019-05-02 09:49:20 -04:00
2019-09-25 18:24:17 -04:00
$contact = DBA :: selectFirst ( 'contact' , [], [ 'id' => $contact_id , 'uid' => $owner_uid , 'blocked' => false , 'pending' => false ]);
2019-05-02 09:49:20 -04:00
2019-09-25 18:24:17 -04:00
$remote_contact = DBA :: isResult ( $contact );
2016-01-04 05:46:19 -05:00
}
2018-01-01 16:47:00 -05:00
if ( ! $remote_contact && local_user ()) {
$contact_id = $_SESSION [ 'cid' ];
2021-07-24 07:49:11 -04:00
$contact = DBA :: selectFirst ( 'contact' , [], [ 'id' => $contact_id , 'uid' => $owner_uid , 'blocked' => false , 'pending' => false ]);
2016-01-04 05:46:19 -05:00
}
2010-08-06 00:15:24 -04:00
2021-07-24 06:09:39 -04:00
if ( $user [ 'hidewall' ] && ( local_user () != $owner_uid ) && ! $remote_contact ) {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Access to this item is restricted.' ));
2011-05-28 03:42:01 -04:00
return ;
}
2019-09-28 05:36:41 -04:00
$sql_extra = Security :: getPermissionsSQLByUserId ( $owner_uid );
2010-08-06 00:15:24 -04:00
2011-06-23 05:30:17 -04:00
$o = " " ;
// tabs
2015-09-29 13:44:26 -04:00
$is_owner = ( local_user () && ( local_user () == $owner_uid ));
2021-08-08 06:14:56 -04:00
$o .= BaseProfile :: getTabsHTML ( $a , 'photos' , $is_owner , $user [ 'nickname' ], $profile [ 'hide-friends' ]);
2011-06-23 05:30:17 -04:00
2018-01-01 16:47:00 -05:00
// Display upload form
2016-10-22 06:14:41 -04:00
if ( $datatype === 'upload' ) {
2017-12-28 15:37:23 -05:00
if ( ! $can_post ) {
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'Permission denied.' ));
2010-08-06 00:15:24 -04:00
return ;
}
2012-01-15 20:48:42 -05:00
2019-05-30 04:30:15 -04:00
$selname = Strings :: isHex ( $datum ) ? hex2bin ( $datum ) : '' ;
2012-01-15 20:48:42 -05:00
2012-07-28 11:57:16 -04:00
$albumselect = '' ;
2010-08-06 00:15:24 -04:00
2018-07-20 15:23:12 -04:00
$albumselect .= '<option value="" ' . ( ! $selname ? ' selected="selected" ' : '' ) . '><current year></option>' ;
2021-07-24 13:49:10 -04:00
$albums = Photo :: getAlbums ( $owner_uid );
if ( ! empty ( $albums )) {
foreach ( $albums as $album ) {
2020-08-18 18:18:48 -04:00
if (( $album [ 'album' ] === '' ) || ( $album [ 'album' ] === Photo :: CONTACT_PHOTOS ) || ( $album [ 'album' ] === DI :: l10n () -> t ( Photo :: CONTACT_PHOTOS ))) {
2010-08-06 00:15:24 -04:00
continue ;
2017-03-25 09:56:23 -04:00
}
2012-01-15 20:48:42 -05:00
$selected = (( $selname === $album [ 'album' ]) ? ' selected="selected" ' : '' );
$albumselect .= '<option value="' . $album [ 'album' ] . '"' . $selected . '>' . $album [ 'album' ] . '</option>' ;
2010-08-06 00:15:24 -04:00
}
}
2010-10-18 03:43:49 -04:00
2011-01-27 21:45:19 -05:00
$uploader = '' ;
2021-07-24 06:09:39 -04:00
$ret = [ 'post_url' => 'photos/' . $user [ 'nickname' ],
2011-01-27 21:45:19 -05:00
'addon_text' => $uploader ,
2018-01-15 08:05:12 -05:00
'default_upload' => true ];
2011-01-27 21:45:19 -05:00
2018-12-26 01:06:24 -05:00
Hook :: callAll ( 'photo_upload_form' , $ret );
2011-01-27 21:45:19 -05:00
2018-10-31 10:44:06 -04:00
$default_upload_box = Renderer :: replaceMacros ( Renderer :: getMarkupTemplate ( 'photos_default_uploader_box.tpl' ), []);
$default_upload_submit = Renderer :: replaceMacros ( Renderer :: getMarkupTemplate ( 'photos_default_uploader_submit.tpl' ), [
2020-01-18 14:52:34 -05:00
'$submit' => DI :: l10n () -> t ( 'Submit' ),
2018-01-15 08:05:12 -05:00
]);
2011-01-27 21:45:19 -05:00
2012-11-25 22:34:54 -05:00
$usage_message = '' ;
2011-01-27 21:45:19 -05:00
2018-10-31 10:44:06 -04:00
$tpl = Renderer :: getMarkupTemplate ( 'photos_upload.tpl' );
2012-12-22 14:57:29 -05:00
2021-08-08 15:30:21 -04:00
$aclselect_e = ( $visitor ? '' : ACL :: getFullSelectorHTML ( DI :: page (), $a -> getUserId ()));
2012-12-22 14:57:29 -05:00
2018-10-31 10:35:50 -04:00
$o .= Renderer :: replaceMacros ( $tpl ,[
2020-01-18 14:52:34 -05:00
'$pagename' => DI :: l10n () -> t ( 'Upload Photos' ),
2010-08-06 00:15:24 -04:00
'$sessid' => session_id (),
2012-06-25 04:37:44 -04:00
'$usage' => $usage_message ,
2021-07-24 06:09:39 -04:00
'$nickname' => $user [ 'nickname' ],
2020-01-18 14:52:34 -05:00
'$newalbum' => DI :: l10n () -> t ( 'New album name: ' ),
'$existalbumtext' => DI :: l10n () -> t ( 'or select existing album:' ),
'$nosharetext' => DI :: l10n () -> t ( 'Do not show a status post for this upload' ),
2018-01-01 16:47:00 -05:00
'$albumselect' => $albumselect ,
2020-01-18 14:52:34 -05:00
'$permissions' => DI :: l10n () -> t ( 'Permissions' ),
2012-12-22 14:57:29 -05:00
'$aclselect' => $aclselect_e ,
2021-08-08 06:14:56 -04:00
'$lockstate' => ACL :: getLockstateForUserId ( $a -> getUserId ()) ? 'lock' : 'unlock' ,
2013-01-26 14:52:21 -05:00
'$alt_uploader' => $ret [ 'addon_text' ],
2017-12-28 15:37:23 -05:00
'$default_upload_box' => ( $ret [ 'default_upload' ] ? $default_upload_box : '' ),
'$default_upload_submit' => ( $ret [ 'default_upload' ] ? $default_upload_submit : '' ),
2013-01-26 14:52:21 -05:00
'$uploadurl' => $ret [ 'post_url' ],
// ACL permissions box
2019-12-15 19:30:34 -05:00
'$return_path' => DI :: args () -> getQueryString (),
2018-01-15 08:05:12 -05:00
]);
2010-08-06 00:15:24 -04:00
2015-06-22 14:07:19 -04:00
return $o ;
2010-08-06 00:15:24 -04:00
}
2018-01-01 16:47:00 -05:00
// Display a single photo album
2016-10-22 06:14:41 -04:00
if ( $datatype === 'album' ) {
2019-05-29 14:28:25 -04:00
// if $datum is not a valid hex, redirect to the default page
if ( ! Strings :: isHex ( $datum )) {
2021-07-24 06:09:39 -04:00
DI :: baseUrl () -> redirect ( 'photos/' . $user [ 'nickname' ] . '/album' );
2019-05-29 14:28:25 -04:00
}
2010-08-06 00:15:24 -04:00
$album = hex2bin ( $datum );
2018-10-24 02:15:24 -04:00
$total = 0 ;
2015-06-22 14:07:19 -04:00
$r = q ( " SELECT `resource-id`, max(`scale`) AS `scale` FROM `photo` WHERE `uid` = %d AND `album` = '%s'
2011-07-28 19:49:43 -04:00
AND `scale` <= 4 $sql_extra GROUP BY `resource-id` " ,
2010-12-05 21:08:36 -05:00
intval ( $owner_uid ),
2018-07-21 09:10:13 -04:00
DBA :: escape ( $album )
2010-08-06 00:15:24 -04:00
);
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $r )) {
2018-10-24 02:15:24 -04:00
$total = count ( $r );
2011-01-04 03:06:36 -05:00
}
2010-08-06 00:15:24 -04:00
2020-02-16 11:53:52 -05:00
$pager = new Pager ( DI :: l10n (), DI :: args () -> getQueryString (), 20 );
2018-10-24 02:15:24 -04:00
2017-03-25 09:56:23 -04:00
/// @TODO I have seen this many times, maybe generalize it script-wide and encapsulate it?
2019-10-15 09:01:17 -04:00
$order_field = $_GET [ 'order' ] ? ? '' ;
2018-01-01 16:47:00 -05:00
if ( $order_field === 'posted' ) {
2012-09-08 21:33:28 -04:00
$order = 'ASC' ;
2017-03-25 09:56:23 -04:00
} else {
2012-09-08 21:33:28 -04:00
$order = 'DESC' ;
2017-03-25 09:56:23 -04:00
}
2012-09-08 21:33:28 -04:00
2017-04-14 18:42:44 -04:00
$r = q ( " SELECT `resource-id`, ANY_VALUE(`id`) AS `id`, ANY_VALUE(`filename`) AS `filename`,
2017-04-20 15:23:45 -04:00
ANY_VALUE ( `type` ) AS `type` , max ( `scale` ) AS `scale` , ANY_VALUE ( `desc` ) as `desc` ,
ANY_VALUE ( `created` ) as `created`
2017-04-14 18:42:44 -04:00
FROM `photo` WHERE `uid` = % d AND `album` = '%s'
AND `scale` <= 4 $sql_extra GROUP BY `resource-id` ORDER BY `created` $order LIMIT % d , % d " ,
2010-12-05 21:08:36 -05:00
intval ( $owner_uid ),
2018-07-21 09:10:13 -04:00
DBA :: escape ( $album ),
2018-10-24 02:15:24 -04:00
$pager -> getStart (),
$pager -> getItemsPerPage ()
2010-08-06 00:15:24 -04:00
);
2019-05-01 19:36:14 -04:00
if ( $cmd === 'drop' ) {
2019-12-15 19:30:34 -05:00
$drop_url = DI :: args () -> getQueryString ();
2019-05-01 19:36:14 -04:00
return Renderer :: replaceMacros ( Renderer :: getMarkupTemplate ( 'confirm.tpl' ), [
'$method' => 'post' ,
2020-01-18 14:52:34 -05:00
'$message' => DI :: l10n () -> t ( 'Do you really want to delete this photo album and all its photos?' ),
'$confirm' => DI :: l10n () -> t ( 'Delete Album' ),
2019-05-01 19:36:14 -04:00
'$confirm_url' => $drop_url ,
'$confirm_name' => 'dropalbum' ,
2020-01-18 14:52:34 -05:00
'$cancel' => DI :: l10n () -> t ( 'Cancel' ),
2019-05-01 19:36:14 -04:00
]);
}
2017-03-25 09:56:23 -04:00
// edit album name
2016-10-22 06:14:41 -04:00
if ( $cmd === 'edit' ) {
2020-08-18 18:18:48 -04:00
if (( $album !== DI :: l10n () -> t ( 'Profile Photos' )) && ( $album !== Photo :: CONTACT_PHOTOS ) && ( $album !== DI :: l10n () -> t ( Photo :: CONTACT_PHOTOS ))) {
2016-10-22 06:14:41 -04:00
if ( $can_post ) {
2018-10-31 10:44:06 -04:00
$edit_tpl = Renderer :: getMarkupTemplate ( 'album_edit.tpl' );
2012-12-22 14:57:29 -05:00
2017-11-27 01:44:49 -05:00
$album_e = $album ;
2012-12-22 14:57:29 -05:00
2018-10-31 10:35:50 -04:00
$o .= Renderer :: replaceMacros ( $edit_tpl ,[
2020-01-18 14:52:34 -05:00
'$nametext' => DI :: l10n () -> t ( 'New album name: ' ),
2021-07-24 06:09:39 -04:00
'$nickname' => $user [ 'nickname' ],
2012-12-22 14:57:29 -05:00
'$album' => $album_e ,
2010-08-08 20:08:39 -04:00
'$hexalbum' => bin2hex ( $album ),
2020-01-18 14:52:34 -05:00
'$submit' => DI :: l10n () -> t ( 'Submit' ),
'$dropsubmit' => DI :: l10n () -> t ( 'Delete Album' )
2018-01-15 08:05:12 -05:00
]);
2010-08-08 20:08:39 -04:00
}
}
2016-10-22 06:14:41 -04:00
} else {
2020-08-18 18:18:48 -04:00
if (( $album !== DI :: l10n () -> t ( 'Profile Photos' )) && ( $album !== Photo :: CONTACT_PHOTOS ) && ( $album !== DI :: l10n () -> t ( Photo :: CONTACT_PHOTOS )) && $can_post ) {
2021-07-24 06:09:39 -04:00
$edit = [ DI :: l10n () -> t ( 'Edit Album' ), 'photos/' . $user [ 'nickname' ] . '/album/' . bin2hex ( $album ) . '/edit' ];
$drop = [ DI :: l10n () -> t ( 'Drop Album' ), 'photos/' . $user [ 'nickname' ] . '/album/' . bin2hex ( $album ) . '/drop' ];
2010-08-08 20:08:39 -04:00
}
}
2012-01-15 20:48:42 -05:00
2018-01-01 16:47:00 -05:00
if ( $order_field === 'posted' ) {
2021-07-24 06:09:39 -04:00
$order = [ DI :: l10n () -> t ( 'Show Newest First' ), 'photos/' . $user [ 'nickname' ] . '/album/' . bin2hex ( $album ), 'oldest' ];
2017-03-25 09:56:23 -04:00
} else {
2021-07-24 06:09:39 -04:00
$order = [ DI :: l10n () -> t ( 'Show Oldest First' ), 'photos/' . $user [ 'nickname' ] . '/album/' . bin2hex ( $album ) . '?order=posted' , 'newest' ];
2017-03-25 09:56:23 -04:00
}
2012-09-08 21:33:28 -04:00
2018-01-15 08:05:12 -05:00
$photos = [];
2012-09-08 21:33:28 -04:00
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $r )) {
2017-12-29 07:47:56 -05:00
// "Twist" is only used for the duepunto theme with style "slackr"
2017-12-28 15:37:23 -05:00
$twist = false ;
2016-10-22 06:14:41 -04:00
foreach ( $r as $rr ) {
2017-12-28 15:37:23 -05:00
$twist = ! $twist ;
2014-02-22 09:46:19 -05:00
2012-06-07 11:42:13 -04:00
$ext = $phototypes [ $rr [ 'type' ]];
2012-05-21 19:40:11 -04:00
2017-11-27 01:44:49 -05:00
$imgalt_e = $rr [ 'filename' ];
$desc_e = $rr [ 'desc' ];
2015-06-22 14:07:19 -04:00
2018-01-15 08:05:12 -05:00
$photos [] = [
2014-12-25 10:20:55 -05:00
'id' => $rr [ 'id' ],
2017-12-28 15:37:23 -05:00
'twist' => ' ' . ( $twist ? 'rotleft' : 'rotright' ) . rand ( 2 , 4 ),
2021-07-24 06:09:39 -04:00
'link' => 'photos/' . $user [ 'nickname' ] . '/image/' . $rr [ 'resource-id' ]
2020-01-13 15:10:13 -05:00
. ( $order_field === 'posted' ? '?order=posted' : '' ),
2020-01-18 14:52:34 -05:00
'title' => DI :: l10n () -> t ( 'View Photo' ),
2016-02-17 17:47:32 -05:00
'src' => 'photo/' . $rr [ 'resource-id' ] . '-' . $rr [ 'scale' ] . '.' . $ext ,
2014-12-25 10:20:55 -05:00
'alt' => $imgalt_e ,
'desc' => $desc_e ,
'ext' => $ext ,
2018-01-01 16:47:00 -05:00
'hash' => $rr [ 'resource-id' ],
2018-01-15 08:05:12 -05:00
];
2018-01-01 16:47:00 -05:00
}
2010-08-06 00:15:24 -04:00
}
2014-12-25 10:20:55 -05:00
2018-10-31 10:44:06 -04:00
$tpl = Renderer :: getMarkupTemplate ( 'photo_album.tpl' );
2018-10-31 10:35:50 -04:00
$o .= Renderer :: replaceMacros ( $tpl , [
2018-10-24 11:42:59 -04:00
'$photos' => $photos ,
'$album' => $album ,
'$can_post' => $can_post ,
2021-07-24 06:09:39 -04:00
'$upload' => [ DI :: l10n () -> t ( 'Upload New Photos' ), 'photos/' . $user [ 'nickname' ] . '/upload/' . bin2hex ( $album )],
2018-10-24 11:42:59 -04:00
'$order' => $order ,
'$edit' => $edit ,
2019-05-01 19:36:14 -04:00
'$drop' => $drop ,
2018-10-24 11:42:59 -04:00
'$paginate' => $pager -> renderFull ( $total ),
]);
2014-12-25 10:20:55 -05:00
2010-08-06 00:15:24 -04:00
return $o ;
2014-02-22 09:46:19 -05:00
}
2010-08-06 00:15:24 -04:00
2018-01-01 16:47:00 -05:00
// Display one photo
2016-10-22 06:14:41 -04:00
if ( $datatype === 'image' ) {
2010-08-07 09:20:27 -04:00
// fetch image, item containing image, then comments
2015-06-22 14:07:19 -04:00
$ph = q ( " SELECT * FROM `photo` WHERE `uid` = %d AND `resource-id` = '%s'
2010-08-06 00:15:24 -04:00
$sql_extra ORDER BY `scale` ASC " ,
2010-12-05 21:08:36 -05:00
intval ( $owner_uid ),
2018-07-21 09:10:13 -04:00
DBA :: escape ( $datum )
2010-08-06 00:15:24 -04:00
);
2018-07-21 08:46:04 -04:00
if ( ! DBA :: isResult ( $ph )) {
2019-05-02 09:49:20 -04:00
if ( DBA :: exists ( 'photo' , [ 'resource-id' => $datum , 'uid' => $owner_uid ])) {
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'Permission denied. Access to this item may be restricted.' ));
2017-03-25 09:32:49 -04:00
} else {
2020-07-23 02:25:01 -04:00
notice ( DI :: l10n () -> t ( 'Photo not available' ));
2017-03-25 09:32:49 -04:00
}
2010-08-06 00:15:24 -04:00
return ;
}
2019-05-01 19:36:14 -04:00
if ( $cmd === 'drop' ) {
2019-12-15 19:30:34 -05:00
$drop_url = DI :: args () -> getQueryString ();
2019-05-01 19:36:14 -04:00
return Renderer :: replaceMacros ( Renderer :: getMarkupTemplate ( 'confirm.tpl' ), [
'$method' => 'post' ,
2020-01-18 14:52:34 -05:00
'$message' => DI :: l10n () -> t ( 'Do you really want to delete this photo?' ),
'$confirm' => DI :: l10n () -> t ( 'Delete Photo' ),
2019-05-01 19:36:14 -04:00
'$confirm_url' => $drop_url ,
'$confirm_name' => 'delete' ,
2020-01-18 14:52:34 -05:00
'$cancel' => DI :: l10n () -> t ( 'Cancel' ),
2019-05-01 19:36:14 -04:00
]);
}
2011-03-11 23:06:13 -05:00
$prevlink = '' ;
$nextlink = '' ;
2017-03-25 10:06:54 -04:00
/*
* @ todo This query is totally bad , the whole functionality has to be changed
* The query leads to a really intense used index .
* By now we hide it if someone wants to .
*/
2020-01-19 15:21:13 -05:00
if ( $cmd === 'view' && ! DI :: config () -> get ( 'system' , 'no_count' , false )) {
2019-10-15 09:01:17 -04:00
$order_field = $_GET [ 'order' ] ? ? '' ;
2018-06-20 16:12:59 -04:00
if ( $order_field === 'posted' ) {
2017-01-15 09:50:26 -05:00
$order = 'ASC' ;
2017-12-28 15:37:23 -05:00
} else {
2017-01-15 09:50:26 -05:00
$order = 'DESC' ;
2017-12-28 15:37:23 -05:00
}
2012-09-08 21:33:28 -04:00
2017-09-15 17:00:39 -04:00
$prvnxt = q ( " SELECT `resource-id` FROM `photo` WHERE `album` = '%s' AND `uid` = %d AND `scale` = 0
2017-01-15 09:50:26 -05:00
$sql_extra ORDER BY `created` $order " ,
2018-07-21 09:10:13 -04:00
DBA :: escape ( $ph [ 0 ][ 'album' ]),
2017-01-15 09:50:26 -05:00
intval ( $owner_uid )
);
2011-03-11 23:06:13 -05:00
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $prvnxt )) {
2018-08-05 09:55:57 -04:00
$prv = null ;
$nxt = null ;
2017-03-25 09:32:49 -04:00
foreach ( $prvnxt as $z => $entry ) {
if ( $entry [ 'resource-id' ] == $ph [ 0 ][ 'resource-id' ]) {
2017-01-15 09:50:26 -05:00
$prv = $z - 1 ;
$nxt = $z + 1 ;
2017-03-25 09:32:49 -04:00
if ( $prv < 0 ) {
2017-01-15 09:50:26 -05:00
$prv = count ( $prvnxt ) - 1 ;
2017-03-25 09:32:49 -04:00
}
if ( $nxt >= count ( $prvnxt )) {
2017-01-15 09:50:26 -05:00
$nxt = 0 ;
2017-03-25 09:32:49 -04:00
}
2017-01-15 09:50:26 -05:00
break ;
}
2011-03-11 23:06:13 -05:00
}
2019-05-01 19:36:14 -04:00
2018-08-05 09:55:57 -04:00
if ( ! is_null ( $prv )) {
2021-07-24 06:09:39 -04:00
$prevlink = 'photos/' . $user [ 'nickname' ] . '/image/' . $prvnxt [ $prv ][ 'resource-id' ] . ( $order_field === 'posted' ? '?order=posted' : '' );
2018-08-05 09:55:57 -04:00
}
if ( ! is_null ( $nxt )) {
2021-07-24 06:09:39 -04:00
$nextlink = 'photos/' . $user [ 'nickname' ] . '/image/' . $prvnxt [ $nxt ][ 'resource-id' ] . ( $order_field === 'posted' ? '?order=posted' : '' );
2019-05-01 19:36:14 -04:00
}
$tpl = Renderer :: getMarkupTemplate ( 'photo_edit_head.tpl' );
2019-12-30 14:02:09 -05:00
DI :: page ()[ 'htmlhead' ] .= Renderer :: replaceMacros ( $tpl ,[
2019-05-01 19:36:14 -04:00
'$prevlink' => $prevlink ,
'$nextlink' => $nextlink
]);
if ( $prevlink ) {
$prevlink = [ $prevlink , '<div class="icon prev"></div>' ];
}
if ( $nextlink ) {
$nextlink = [ $nextlink , '<div class="icon next"></div>' ];
2018-08-05 09:55:57 -04:00
}
2017-01-15 09:50:26 -05:00
}
}
2011-03-11 23:06:13 -05:00
2017-01-26 09:23:30 -05:00
if ( count ( $ph ) == 1 ) {
2010-08-06 09:30:25 -04:00
$hires = $lores = $ph [ 0 ];
2017-01-26 09:23:30 -05:00
}
2018-05-14 16:34:11 -04:00
2016-10-22 06:14:41 -04:00
if ( count ( $ph ) > 1 ) {
if ( $ph [ 1 ][ 'scale' ] == 2 ) {
2010-08-06 20:16:52 -04:00
// original is 640 or less, we can display it directly
$hires = $lores = $ph [ 0 ];
2016-10-22 06:14:41 -04:00
} else {
$hires = $ph [ 0 ];
$lores = $ph [ 1 ];
2010-08-06 20:16:52 -04:00
}
2010-08-06 00:15:24 -04:00
}
2021-07-24 06:09:39 -04:00
$album_link = 'photos/' . $user [ 'nickname' ] . '/album/' . bin2hex ( $ph [ 0 ][ 'album' ]);
2017-03-25 09:32:49 -04:00
2017-03-25 09:57:40 -04:00
$tools = null ;
2014-02-22 09:46:19 -05:00
2016-10-22 06:14:41 -04:00
if ( $can_post && ( $ph [ 0 ][ 'uid' ] == $owner_uid )) {
2019-05-01 19:36:14 -04:00
$tools = [];
if ( $cmd === 'edit' ) {
2021-07-24 06:09:39 -04:00
$tools [ 'view' ] = [ 'photos/' . $user [ 'nickname' ] . '/image/' . $datum , DI :: l10n () -> t ( 'View photo' )];
2019-05-01 19:36:14 -04:00
} else {
2021-07-24 06:09:39 -04:00
$tools [ 'edit' ] = [ 'photos/' . $user [ 'nickname' ] . '/image/' . $datum . '/edit' , DI :: l10n () -> t ( 'Edit photo' )];
$tools [ 'delete' ] = [ 'photos/' . $user [ 'nickname' ] . '/image/' . $datum . '/drop' , DI :: l10n () -> t ( 'Delete photo' )];
2019-10-27 09:56:27 -04:00
$tools [ 'profile' ] = [ 'settings/profile/photo/crop/' . $ph [ 0 ][ 'resource-id' ], DI :: l10n () -> t ( 'Use as profile photo' )];
2019-05-01 19:36:14 -04:00
}
2012-03-19 04:20:53 -04:00
2019-05-01 19:36:14 -04:00
if (
$ph [ 0 ][ 'uid' ] == local_user ()
&& ( strlen ( $ph [ 0 ][ 'allow_cid' ]) || strlen ( $ph [ 0 ][ 'allow_gid' ]) || strlen ( $ph [ 0 ][ 'deny_cid' ]) || strlen ( $ph [ 0 ][ 'deny_gid' ]))
) {
2020-01-18 14:52:34 -05:00
$tools [ 'lock' ] = DI :: l10n () -> t ( 'Private Photo' );
2019-05-01 19:36:14 -04:00
}
2017-01-26 09:23:30 -05:00
}
2010-08-08 04:58:26 -04:00
2018-01-15 08:05:12 -05:00
$photo = [
2016-02-17 17:47:32 -05:00
'href' => 'photo/' . $hires [ 'resource-id' ] . '-' . $hires [ 'scale' ] . '.' . $phototypes [ $hires [ 'type' ]],
2020-01-18 14:52:34 -05:00
'title' => DI :: l10n () -> t ( 'View Full Size' ),
2020-01-13 15:10:13 -05:00
'src' => 'photo/' . $lores [ 'resource-id' ] . '-' . $lores [ 'scale' ] . '.' . $phototypes [ $lores [ 'type' ]] . '?_u=' . DateTimeFormat :: utcNow ( 'ymdhis' ),
2014-02-22 09:46:19 -05:00
'height' => $hires [ 'height' ],
'width' => $hires [ 'width' ],
'album' => $hires [ 'album' ],
'filename' => $hires [ 'filename' ],
2018-01-15 08:05:12 -05:00
];
2011-03-11 23:06:13 -05:00
2019-07-07 23:51:23 -04:00
$map = null ;
$link_item = [];
$total = 0 ;
2010-08-06 09:30:25 -04:00
// Do we have an item for this photo?
2014-02-22 09:46:19 -05:00
// FIXME! - replace following code to display the conversation with our normal
2012-09-29 09:04:01 -04:00
// conversation functions so that it works correctly and tracks changes
// in the evolving conversation code.
// The difference is that we won't be displaying the conversation head item
// as a "post" but displaying instead the photo it is linked to
2018-06-19 15:06:17 -04:00
/// @todo Rewrite this query. To do so, $sql_extra must be changed
2021-02-22 14:47:08 -05:00
$linked_items = q ( " SELECT `id` FROM `post-user-view` WHERE `resource-id` = '%s' $sql_extra LIMIT 1 " ,
2018-07-21 09:10:13 -04:00
DBA :: escape ( $datum )
2010-08-06 09:30:25 -04:00
);
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $linked_items )) {
2018-06-19 15:06:17 -04:00
// This is a workaround to not being forced to rewrite the while $sql_extra handling
2021-01-15 23:11:28 -05:00
$link_item = Post :: selectFirst ([], [ 'id' => $linked_items [ 0 ][ 'id' ]]);
2019-07-07 23:51:23 -04:00
}
2010-08-06 09:30:25 -04:00
2019-07-07 23:51:23 -04:00
if ( ! empty ( $link_item [ 'parent' ]) && ! empty ( $link_item [ 'uid' ])) {
2021-05-24 14:04:47 -04:00
$condition = [ " `parent` = ? AND `gravity` = ? " , $link_item [ 'parent' ], GRAVITY_COMMENT ];
2021-01-16 17:37:27 -05:00
$total = Post :: count ( $condition );
2018-10-24 11:42:59 -04:00
2020-02-16 11:53:52 -05:00
$pager = new Pager ( DI :: l10n (), DI :: args () -> getQueryString ());
2010-08-06 09:30:25 -04:00
2018-10-24 02:15:24 -04:00
$params = [ 'order' => [ 'id' ], 'limit' => [ $pager -> getStart (), $pager -> getItemsPerPage ()]];
2021-01-16 17:37:27 -05:00
$items = Post :: toArray ( Post :: selectForUser ( $link_item [ 'uid' ], Item :: ITEM_FIELDLIST , $condition , $params ));
2013-01-13 09:11:06 -05:00
2019-07-07 23:51:23 -04:00
if ( local_user () == $link_item [ 'uid' ]) {
2018-02-06 07:40:22 -05:00
Item :: update ([ 'unseen' => false ], [ 'parent' => $link_item [ 'parent' ]]);
2010-11-04 03:19:10 -04:00
}
2019-07-07 23:51:23 -04:00
}
2015-09-29 18:19:54 -04:00
2019-07-07 23:51:23 -04:00
if ( ! empty ( $link_item [ 'coord' ])) {
$map = Map :: byCoordinates ( $link_item [ 'coord' ]);
2010-08-08 20:08:39 -04:00
}
2010-08-06 00:15:24 -04:00
2017-03-25 09:32:49 -04:00
$tags = null ;
2011-07-03 22:57:20 -04:00
2020-05-06 00:58:25 -04:00
if ( ! empty ( $link_item [ 'id' ])) {
$tag_text = Tag :: getCSVByURIId ( $link_item [ 'uri-id' ]);
2020-05-05 15:54:25 -04:00
$arr = explode ( ',' , $tag_text );
2011-05-05 04:53:03 -04:00
// parse tags and add links
2018-10-23 05:40:20 -04:00
$tag_arr = [];
2018-10-23 13:29:59 -04:00
foreach ( $arr as $tag ) {
2018-10-25 18:18:47 -04:00
$tag_arr [] = [
'name' => BBCode :: convert ( $tag ),
2019-07-07 23:51:23 -04:00
'removeurl' => '/tagrm/' . $link_item [ 'id' ] . '/' . bin2hex ( $tag )
2018-10-25 18:18:47 -04:00
];
2014-02-22 09:46:19 -05:00
}
2020-01-18 14:52:34 -05:00
$tags = [ 'title' => DI :: l10n () -> t ( 'Tags: ' ), 'tags' => $tag_arr ];
2016-10-22 06:14:41 -04:00
if ( $cmd === 'edit' ) {
2018-10-25 18:18:47 -04:00
$tags [ 'removeanyurl' ] = 'tagrm/' . $link_item [ 'id' ];
2020-01-18 14:52:34 -05:00
$tags [ 'removetitle' ] = DI :: l10n () -> t ( '[Select tags to remove]' );
2011-06-09 00:43:32 -04:00
}
2010-08-08 20:08:39 -04:00
}
2010-08-08 04:58:26 -04:00
2010-11-04 23:47:44 -04:00
2011-05-05 04:53:03 -04:00
$edit = Null ;
2018-01-01 16:47:00 -05:00
if ( $cmd === 'edit' && $can_post ) {
2018-10-31 10:44:06 -04:00
$edit_tpl = Renderer :: getMarkupTemplate ( 'photo_edit.tpl' );
2012-12-22 14:57:29 -05:00
2017-11-27 01:44:49 -05:00
$album_e = $ph [ 0 ][ 'album' ];
$caption_e = $ph [ 0 ][ 'desc' ];
2021-08-08 15:30:21 -04:00
$aclselect_e = ACL :: getFullSelectorHTML ( DI :: page (), $a -> getUserId (), false , ACL :: getDefaultUserPermissions ( $ph [ 0 ]));
2012-12-22 14:57:29 -05:00
2018-10-31 10:35:50 -04:00
$edit = Renderer :: replaceMacros ( $edit_tpl , [
2010-08-08 20:08:39 -04:00
'$id' => $ph [ 0 ][ 'id' ],
2020-01-18 14:52:34 -05:00
'$album' => [ 'albname' , DI :: l10n () -> t ( 'New album name' ), $album_e , '' ],
'$caption' => [ 'desc' , DI :: l10n () -> t ( 'Caption' ), $caption_e , '' ],
'$tags' => [ 'newtag' , DI :: l10n () -> t ( 'Add a Tag' ), " " , DI :: l10n () -> t ( 'Example: @bob, @Barbara_Jensen, @jim@example.com, #California, #camping' )],
'$rotate_none' => [ 'rotate' , DI :: l10n () -> t ( 'Do not rotate' ), 0 , '' , true ],
'$rotate_cw' => [ 'rotate' , DI :: l10n () -> t ( " Rotate CW \x28 right \x29 " ), 1 , '' ],
'$rotate_ccw' => [ 'rotate' , DI :: l10n () -> t ( " Rotate CCW \x28 left \x29 " ), 2 , '' ],
2015-06-22 14:07:19 -04:00
2021-07-24 06:09:39 -04:00
'$nickname' => $user [ 'nickname' ],
2010-08-08 20:08:39 -04:00
'$resource_id' => $ph [ 0 ][ 'resource-id' ],
2020-01-18 14:52:34 -05:00
'$permissions' => DI :: l10n () -> t ( 'Permissions' ),
2012-12-22 14:57:29 -05:00
'$aclselect' => $aclselect_e ,
2015-06-22 14:07:19 -04:00
2019-07-07 23:51:23 -04:00
'$item_id' => $link_item [ 'id' ] ? ? 0 ,
2020-01-18 14:52:34 -05:00
'$submit' => DI :: l10n () -> t ( 'Submit' ),
'$delete' => DI :: l10n () -> t ( 'Delete Photo' ),
2013-01-26 14:52:21 -05:00
// ACL permissions box
2019-12-15 19:30:34 -05:00
'$return_path' => DI :: args () -> getQueryString (),
2018-01-15 08:05:12 -05:00
]);
2010-08-08 20:08:39 -04:00
}
2010-08-07 09:20:27 -04:00
2018-01-01 16:47:00 -05:00
$like = '' ;
$dislike = '' ;
$likebuttons = '' ;
$comments = '' ;
$paginate = '' ;
2010-08-06 09:30:25 -04:00
2019-07-07 23:51:23 -04:00
if ( ! empty ( $link_item [ 'id' ]) && ! empty ( $link_item [ 'uri' ])) {
2018-10-31 10:44:06 -04:00
$cmnt_tpl = Renderer :: getMarkupTemplate ( 'comment_item.tpl' );
$tpl = Renderer :: getMarkupTemplate ( 'photo_item.tpl' );
2019-12-15 19:33:13 -05:00
$return_path = DI :: args () -> getCommand ();
2010-08-06 09:30:25 -04:00
2018-07-21 08:46:04 -04:00
if ( ! DBA :: isResult ( $items )) {
2018-10-17 15:30:41 -04:00
if (( $can_post || Security :: canWriteToUserWall ( $owner_uid ))) {
2020-09-09 16:49:03 -04:00
/*
* Hmmm , code depending on the presence of a particular addon ?
* This should be better if done by a hook
*/
$qcomment = null ;
if ( Addon :: isEnabled ( 'qcomment' )) {
$words = DI :: pConfig () -> get ( local_user (), 'qcomment' , 'words' );
$qcomment = $words ? explode ( " \n " , $words ) : [];
}
2018-10-31 10:35:50 -04:00
$comments .= Renderer :: replaceMacros ( $cmnt_tpl , [
2017-03-30 15:48:46 -04:00
'$return_path' => '' ,
2018-10-19 17:55:11 -04:00
'$jsreload' => $return_path ,
2017-03-30 15:48:46 -04:00
'$id' => $link_item [ 'id' ],
'$parent' => $link_item [ 'id' ],
'$profile_uid' => $owner_uid ,
'$mylink' => $contact [ 'url' ],
2020-01-18 14:52:34 -05:00
'$mytitle' => DI :: l10n () -> t ( 'This is you' ),
2017-03-30 15:48:46 -04:00
'$myphoto' => $contact [ 'thumb' ],
2020-01-18 14:52:34 -05:00
'$comment' => DI :: l10n () -> t ( 'Comment' ),
'$submit' => DI :: l10n () -> t ( 'Submit' ),
'$preview' => DI :: l10n () -> t ( 'Preview' ),
2020-02-11 23:45:47 -05:00
'$loading' => DI :: l10n () -> t ( 'Loading...' ),
2020-09-09 16:49:03 -04:00
'$qcomment' => $qcomment ,
2018-11-05 03:37:03 -05:00
'$rand_num' => Crypto :: randomDigits ( 12 )
2018-01-15 08:05:12 -05:00
]);
2010-08-06 09:30:25 -04:00
}
}
2018-01-15 08:05:12 -05:00
$conv_responses = [
2020-02-22 20:41:12 -05:00
'like' => [],
'dislike' => [],
'attendyes' => [],
'attendno' => [],
'attendmaybe' => []
2018-01-15 08:05:12 -05:00
];
2015-06-03 22:19:06 -04:00
2020-02-19 22:20:26 -05:00
if ( DI :: pConfig () -> get ( local_user (), 'system' , 'hide_dislike' )) {
unset ( $conv_responses [ 'dislike' ]);
}
2010-08-06 09:30:25 -04:00
// display comments
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $items )) {
2018-06-23 06:32:53 -04:00
foreach ( $items as $item ) {
2015-06-03 22:19:06 -04:00
builtin_activity_puller ( $item , $conv_responses );
2010-11-02 19:24:23 -04:00
}
2018-07-22 21:19:28 -04:00
if ( ! empty ( $conv_responses [ 'like' ][ $link_item [ 'uri' ]])) {
2020-11-21 11:08:44 -05:00
$like = format_activity ( $conv_responses [ 'like' ][ $link_item [ 'uri' ]][ 'links' ], 'like' , $link_item [ 'id' ]);
2018-01-01 16:47:00 -05:00
}
2018-07-22 21:19:28 -04:00
if ( ! empty ( $conv_responses [ 'dislike' ][ $link_item [ 'uri' ]])) {
2020-11-21 11:08:44 -05:00
$dislike = format_activity ( $conv_responses [ 'dislike' ][ $link_item [ 'uri' ]][ 'links' ], 'dislike' , $link_item [ 'id' ]);
2018-01-01 16:47:00 -05:00
}
2010-11-02 19:24:23 -04:00
2018-10-17 15:30:41 -04:00
if (( $can_post || Security :: canWriteToUserWall ( $owner_uid ))) {
2020-09-09 16:49:03 -04:00
/*
* Hmmm , code depending on the presence of a particular addon ?
* This should be better if done by a hook
*/
$qcomment = null ;
if ( Addon :: isEnabled ( 'qcomment' )) {
$words = DI :: pConfig () -> get ( local_user (), 'qcomment' , 'words' );
$qcomment = $words ? explode ( " \n " , $words ) : [];
}
2018-10-31 10:35:50 -04:00
$comments .= Renderer :: replaceMacros ( $cmnt_tpl ,[
2017-03-30 15:48:46 -04:00
'$return_path' => '' ,
2018-10-19 17:55:11 -04:00
'$jsreload' => $return_path ,
2017-03-30 15:48:46 -04:00
'$id' => $link_item [ 'id' ],
'$parent' => $link_item [ 'id' ],
'$profile_uid' => $owner_uid ,
'$mylink' => $contact [ 'url' ],
2020-01-18 14:52:34 -05:00
'$mytitle' => DI :: l10n () -> t ( 'This is you' ),
2017-03-30 15:48:46 -04:00
'$myphoto' => $contact [ 'thumb' ],
2020-01-18 14:52:34 -05:00
'$comment' => DI :: l10n () -> t ( 'Comment' ),
'$submit' => DI :: l10n () -> t ( 'Submit' ),
'$preview' => DI :: l10n () -> t ( 'Preview' ),
2020-09-09 16:49:03 -04:00
'$qcomment' => $qcomment ,
2018-11-05 03:37:03 -05:00
'$rand_num' => Crypto :: randomDigits ( 12 )
2018-01-15 08:05:12 -05:00
]);
2010-11-04 03:19:10 -04:00
}
2018-06-23 06:32:53 -04:00
foreach ( $items as $item ) {
2010-08-06 09:30:25 -04:00
$comment = '' ;
$template = $tpl ;
2010-11-02 19:24:23 -04:00
2019-12-15 17:28:01 -05:00
$activity = DI :: activity ();
2019-10-22 20:05:11 -04:00
2019-10-23 18:25:43 -04:00
if (( $activity -> match ( $item [ 'verb' ], Activity :: LIKE ) ||
$activity -> match ( $item [ 'verb' ], Activity :: DISLIKE )) &&
2020-05-27 08:19:06 -04:00
( $item [ 'gravity' ] != GRAVITY_PARENT )) {
2010-11-02 19:24:23 -04:00
continue ;
2018-01-01 16:47:00 -05:00
}
2010-11-02 19:24:23 -04:00
2021-02-17 13:59:19 -05:00
$author = [ 'uid' => 0 , 'id' => $item [ 'author-id' ],
'network' => $item [ 'author-network' ], 'url' => $item [ 'author-link' ]];
$profile_url = Contact :: magicLinkByContact ( $author );
2018-06-02 04:05:06 -04:00
if ( strpos ( $profile_url , 'redir/' ) === 0 ) {
2010-09-27 22:48:45 -04:00
$sparkle = ' sparkle' ;
2016-10-22 06:14:41 -04:00
} else {
2010-09-27 22:48:45 -04:00
$sparkle = '' ;
}
2014-02-22 09:46:19 -05:00
2016-01-04 05:46:19 -05:00
$dropping = (( $item [ 'contact-id' ] == $contact_id ) || ( $item [ 'uid' ] == local_user ()));
2018-01-15 08:05:12 -05:00
$drop = [
2014-04-28 09:29:48 -04:00
'dropping' => $dropping ,
'pagedrop' => false ,
2020-01-18 14:52:34 -05:00
'select' => DI :: l10n () -> t ( 'Select' ),
'delete' => DI :: l10n () -> t ( 'Delete' ),
2018-01-15 08:05:12 -05:00
];
2010-08-06 09:30:25 -04:00
2017-11-27 01:44:49 -05:00
$title_e = $item [ 'title' ];
2018-02-14 21:33:55 -05:00
$body_e = BBCode :: convert ( $item [ 'body' ]);
2012-12-22 14:57:29 -05:00
2018-10-31 10:35:50 -04:00
$comments .= Renderer :: replaceMacros ( $template ,[
2018-08-24 07:09:58 -04:00
'$id' => $item [ 'id' ],
2018-06-23 06:32:53 -04:00
'$profile_url' => $profile_url ,
'$name' => $item [ 'author-name' ],
'$thumb' => $item [ 'author-avatar' ],
2010-09-27 22:48:45 -04:00
'$sparkle' => $sparkle ,
2012-12-22 14:57:29 -05:00
'$title' => $title_e ,
'$body' => $body_e ,
2018-02-03 12:25:58 -05:00
'$ago' => Temporal :: getRelativeDate ( $item [ 'created' ]),
2019-05-29 15:40:21 -04:00
'$indent' => (( $item [ 'parent' ] != $item [ 'id' ]) ? ' comment' : '' ),
2010-08-06 09:30:25 -04:00
'$drop' => $drop ,
'$comment' => $comment
2018-01-15 08:05:12 -05:00
]);
2012-10-14 14:30:10 -04:00
2018-10-17 15:30:41 -04:00
if (( $can_post || Security :: canWriteToUserWall ( $owner_uid ))) {
2020-09-09 16:49:03 -04:00
/*
* Hmmm , code depending on the presence of a particular addon ?
* This should be better if done by a hook
*/
$qcomment = null ;
if ( Addon :: isEnabled ( 'qcomment' )) {
$words = DI :: pConfig () -> get ( local_user (), 'qcomment' , 'words' );
$qcomment = $words ? explode ( " \n " , $words ) : [];
}
2018-10-31 10:35:50 -04:00
$comments .= Renderer :: replaceMacros ( $cmnt_tpl , [
2017-03-30 15:48:46 -04:00
'$return_path' => '' ,
2018-10-19 17:55:11 -04:00
'$jsreload' => $return_path ,
2019-05-29 15:40:21 -04:00
'$id' => $item [ 'id' ],
2017-03-30 15:48:46 -04:00
'$parent' => $item [ 'parent' ],
'$profile_uid' => $owner_uid ,
'$mylink' => $contact [ 'url' ],
2020-01-18 14:52:34 -05:00
'$mytitle' => DI :: l10n () -> t ( 'This is you' ),
2017-03-30 15:48:46 -04:00
'$myphoto' => $contact [ 'thumb' ],
2020-01-18 14:52:34 -05:00
'$comment' => DI :: l10n () -> t ( 'Comment' ),
'$submit' => DI :: l10n () -> t ( 'Submit' ),
'$preview' => DI :: l10n () -> t ( 'Preview' ),
2020-09-09 16:49:03 -04:00
'$qcomment' => $qcomment ,
2018-11-05 03:37:03 -05:00
'$rand_num' => Crypto :: randomDigits ( 12 )
2018-01-15 08:05:12 -05:00
]);
2012-10-14 14:30:10 -04:00
}
2010-08-06 09:30:25 -04:00
}
}
2020-02-19 22:20:26 -05:00
2020-11-21 11:10:04 -05:00
$responses = [];
foreach ( $conv_responses as $verb => $activity ) {
if ( isset ( $activity [ $link_item [ 'uri' ]])) {
$responses [ $verb ] = $activity [ $link_item [ 'uri' ]];
}
}
if ( $cmd === 'view' && ( $can_post || Security :: canWriteToUserWall ( $owner_uid ))) {
$like_tpl = Renderer :: getMarkupTemplate ( 'like_noshare.tpl' );
$likebuttons = Renderer :: replaceMacros ( $like_tpl , [
'$id' => $link_item [ 'id' ],
'$like' => DI :: l10n () -> t ( 'Like' ),
'$like_title' => DI :: l10n () -> t ( 'I like this (toggle)' ),
'$dislike' => DI :: l10n () -> t ( 'Dislike' ),
'$wait' => DI :: l10n () -> t ( 'Please wait' ),
'$dislike_title' => DI :: l10n () -> t ( 'I don\'t like this (toggle)' ),
'$hide_dislike' => DI :: pConfig () -> get ( local_user (), 'system' , 'hide_dislike' ),
'$responses' => $responses ,
'$return_path' => DI :: args () -> getQueryString (),
]);
}
2018-10-24 11:42:59 -04:00
$paginate = $pager -> renderFull ( $total );
2010-08-06 09:30:25 -04:00
}
2014-02-22 09:46:19 -05:00
2018-10-31 10:44:06 -04:00
$photo_tpl = Renderer :: getMarkupTemplate ( 'photo_view.tpl' );
2018-10-31 10:35:50 -04:00
$o .= Renderer :: replaceMacros ( $photo_tpl , [
2011-05-05 04:53:03 -04:00
'$id' => $ph [ 0 ][ 'id' ],
2018-01-01 16:47:00 -05:00
'$album' => [ $album_link , $ph [ 0 ][ 'album' ]],
2011-05-05 04:53:03 -04:00
'$tools' => $tools ,
'$photo' => $photo ,
'$prevlink' => $prevlink ,
'$nextlink' => $nextlink ,
'$desc' => $ph [ 0 ][ 'desc' ],
2018-01-01 16:47:00 -05:00
'$tags' => $tags ,
2014-02-22 09:46:19 -05:00
'$edit' => $edit ,
2015-09-29 18:19:54 -04:00
'$map' => $map ,
2020-01-18 14:52:34 -05:00
'$map_text' => DI :: l10n () -> t ( 'Map' ),
2011-05-05 04:53:03 -04:00
'$likebuttons' => $likebuttons ,
2018-01-01 16:47:00 -05:00
'$like' => $like ,
'$dislike' => $dislike ,
2011-05-05 04:53:03 -04:00
'$comments' => $comments ,
'$paginate' => $paginate ,
2018-01-15 08:05:12 -05:00
]);
2014-02-22 09:46:19 -05:00
2019-12-30 14:02:09 -05:00
DI :: page ()[ 'htmlhead' ] .= " \n " . '<meta name="twitter:card" content="summary_large_image" />' . " \n " ;
DI :: page ()[ 'htmlhead' ] .= '<meta name="twitter:title" content="' . $photo [ " album " ] . '" />' . " \n " ;
2019-12-30 17:00:08 -05:00
DI :: page ()[ 'htmlhead' ] .= '<meta name="twitter:image" content="' . DI :: baseUrl () . " / " . $photo [ " href " ] . '" />' . " \n " ;
2019-12-30 14:02:09 -05:00
DI :: page ()[ 'htmlhead' ] .= '<meta name="twitter:image:width" content="' . $photo [ " width " ] . '" />' . " \n " ;
DI :: page ()[ 'htmlhead' ] .= '<meta name="twitter:image:height" content="' . $photo [ " height " ] . '" />' . " \n " ;
2014-02-22 09:46:19 -05:00
2010-08-06 00:15:24 -04:00
return $o ;
}
// Default - show recent photos with upload link (if applicable)
2011-06-23 05:30:17 -04:00
//$o = '';
2018-10-24 11:42:59 -04:00
$total = 0 ;
2017-09-15 17:00:39 -04:00
$r = q ( " SELECT `resource-id`, max(`scale`) AS `scale` FROM `photo` WHERE `uid` = %d AND `album` != '%s' AND `album` != '%s'
2010-08-06 00:15:24 -04:00
$sql_extra GROUP BY `resource-id` " ,
2021-07-24 06:09:39 -04:00
intval ( $user [ 'uid' ]),
2020-08-18 18:18:48 -04:00
DBA :: escape ( Photo :: CONTACT_PHOTOS ),
DBA :: escape ( DI :: l10n () -> t ( Photo :: CONTACT_PHOTOS ))
2010-08-06 00:15:24 -04:00
);
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $r )) {
2018-10-24 11:42:59 -04:00
$total = count ( $r );
2011-01-04 03:06:36 -05:00
}
2010-08-06 00:15:24 -04:00
2020-02-16 11:53:52 -05:00
$pager = new Pager ( DI :: l10n (), DI :: args () -> getQueryString (), 20 );
2018-10-24 11:42:59 -04:00
2017-09-15 17:00:39 -04:00
$r = q ( " SELECT `resource-id`, ANY_VALUE(`id`) AS `id`, ANY_VALUE(`filename`) AS `filename`,
2017-04-20 15:23:45 -04:00
ANY_VALUE ( `type` ) AS `type` , ANY_VALUE ( `album` ) AS `album` , max ( `scale` ) AS `scale` ,
ANY_VALUE ( `created` ) AS `created` FROM `photo`
2015-06-22 14:07:19 -04:00
WHERE `uid` = % d AND `album` != '%s' AND `album` != '%s'
2010-08-06 00:15:24 -04:00
$sql_extra GROUP BY `resource-id` ORDER BY `created` DESC LIMIT % d , % d " ,
2021-07-24 06:09:39 -04:00
intval ( $user [ 'uid' ]),
2020-08-18 18:18:48 -04:00
DBA :: escape ( Photo :: CONTACT_PHOTOS ),
DBA :: escape ( DI :: l10n () -> t ( Photo :: CONTACT_PHOTOS )),
2018-10-24 02:15:24 -04:00
$pager -> getStart (),
$pager -> getItemsPerPage ()
2010-08-06 00:15:24 -04:00
);
2018-01-15 08:05:12 -05:00
$photos = [];
2018-07-21 08:46:04 -04:00
if ( DBA :: isResult ( $r )) {
2017-12-29 07:47:56 -05:00
// "Twist" is only used for the duepunto theme with style "slackr"
2017-12-28 15:37:23 -05:00
$twist = false ;
2016-10-22 06:14:41 -04:00
foreach ( $r as $rr ) {
2015-09-29 13:44:26 -04:00
//hide profile photos to others
2020-01-18 14:52:34 -05:00
if ( ! $is_owner && ! Session :: getRemoteContactID ( $owner_uid ) && ( $rr [ 'album' ] == DI :: l10n () -> t ( 'Profile Photos' ))) {
2017-12-28 15:37:23 -05:00
continue ;
2017-03-21 17:39:53 -04:00
}
2016-10-22 06:14:41 -04:00
2017-12-28 15:37:23 -05:00
$twist = ! $twist ;
2012-06-07 11:42:13 -04:00
$ext = $phototypes [ $rr [ 'type' ]];
2015-06-22 14:07:19 -04:00
2017-11-27 01:44:49 -05:00
$alt_e = $rr [ 'filename' ];
$name_e = $rr [ 'album' ];
2012-12-22 14:57:29 -05:00
2018-01-15 08:05:12 -05:00
$photos [] = [
2018-07-22 21:19:28 -04:00
'id' => $rr [ 'id' ],
'twist' => ' ' . ( $twist ? 'rotleft' : 'rotright' ) . rand ( 2 , 4 ),
2021-07-24 06:09:39 -04:00
'link' => 'photos/' . $user [ 'nickname' ] . '/image/' . $rr [ 'resource-id' ],
2020-01-18 14:52:34 -05:00
'title' => DI :: l10n () -> t ( 'View Photo' ),
2018-07-22 21:19:28 -04:00
'src' => 'photo/' . $rr [ 'resource-id' ] . '-' . ((( $rr [ 'scale' ]) == 6 ) ? 4 : $rr [ 'scale' ]) . '.' . $ext ,
'alt' => $alt_e ,
'album' => [
2021-07-24 06:09:39 -04:00
'link' => 'photos/' . $user [ 'nickname' ] . '/album/' . bin2hex ( $rr [ 'album' ]),
2018-07-22 21:19:28 -04:00
'name' => $name_e ,
2020-01-18 14:52:34 -05:00
'alt' => DI :: l10n () -> t ( 'View Album' ),
2018-01-15 08:05:12 -05:00
],
2014-02-22 09:46:19 -05:00
2018-01-15 08:05:12 -05:00
];
2010-08-06 00:15:24 -04:00
}
}
2014-02-22 09:46:19 -05:00
2018-10-31 10:44:06 -04:00
$tpl = Renderer :: getMarkupTemplate ( 'photos_recent.tpl' );
2018-10-31 10:35:50 -04:00
$o .= Renderer :: replaceMacros ( $tpl , [
2020-01-18 14:52:34 -05:00
'$title' => DI :: l10n () -> t ( 'Recent Photos' ),
2016-01-04 05:46:19 -05:00
'$can_post' => $can_post ,
2021-07-25 01:04:48 -04:00
'$upload' => [ DI :: l10n () -> t ( 'Upload New Photos' ), 'photos/' . $user [ 'nickname' ] . '/upload' ],
2011-12-22 10:33:14 -05:00
'$photos' => $photos ,
2018-10-24 11:42:59 -04:00
'$paginate' => $pager -> renderFull ( $total ),
2018-01-15 08:05:12 -05:00
]);
2011-12-22 10:33:14 -05:00
2010-08-06 00:15:24 -04:00
return $o ;
}