2019-10-27 15:08:14 +01:00
< ? php
namespace Friendica\Module\Profile ;
use Friendica\Content\Nav ;
use Friendica\Content\Pager ;
use Friendica\Content\Widget ;
use Friendica\Core\ACL ;
use Friendica\Core\Session ;
use Friendica\Database\DBA ;
use Friendica\DI ;
use Friendica\Model\Item ;
use Friendica\Model\Profile as ProfileModel ;
use Friendica\Model\User ;
2020-01-26 15:49:11 +01:00
use Friendica\Module\BaseProfile ;
2019-10-27 15:08:14 +01:00
use Friendica\Module\Security\Login ;
use Friendica\Util\DateTimeFormat ;
use Friendica\Util\Security ;
use Friendica\Util\Strings ;
use Friendica\Util\XML ;
2020-01-26 15:49:11 +01:00
class Status extends BaseProfile
2019-10-27 15:08:14 +01:00
{
public static function content ( array $parameters = [])
{
$args = DI :: args ();
$a = DI :: app ();
ProfileModel :: load ( $a , $parameters [ 'nickname' ]);
if ( ! $a -> profile [ 'net-publish' ] || $a -> profile [ 'hidewall' ]) {
DI :: page ()[ 'htmlhead' ] .= '<meta content="noindex, noarchive" name="robots" />' . " \n " ;
}
DI :: page ()[ 'htmlhead' ] .= '<link rel="alternate" type="application/atom+xml" href="' . DI :: baseUrl () . '/dfrn_poll/' . $parameters [ 'nickname' ] . '" title="DFRN: ' . DI :: l10n () -> t ( '%s\'s timeline' , $a -> profile [ 'username' ]) . '"/>' . " \n " ;
DI :: page ()[ 'htmlhead' ] .= '<link rel="alternate" type="application/atom+xml" href="' . DI :: baseUrl () . '/feed/' . $parameters [ 'nickname' ] . '/" title="' . DI :: l10n () -> t ( '%s\'s posts' , $a -> profile [ 'username' ]) . '"/>' . " \n " ;
DI :: page ()[ 'htmlhead' ] .= '<link rel="alternate" type="application/atom+xml" href="' . DI :: baseUrl () . '/feed/' . $parameters [ 'nickname' ] . '/comments" title="' . DI :: l10n () -> t ( '%s\'s comments' , $a -> profile [ 'username' ]) . '"/>' . " \n " ;
DI :: page ()[ 'htmlhead' ] .= '<link rel="alternate" type="application/atom+xml" href="' . DI :: baseUrl () . '/feed/' . $parameters [ 'nickname' ] . '/activity" title="' . DI :: l10n () -> t ( '%s\'s timeline' , $a -> profile [ 'username' ]) . '"/>' . " \n " ;
$category = $datequery = $datequery2 = '' ;
$dtFormat = DI :: dtFormat ();
2020-01-25 22:23:09 +01:00
if ( $args -> getArgc () > 3 ) {
for ( $x = 3 ; $x < $args -> getArgc (); $x ++ ) {
2019-10-27 15:08:14 +01:00
if ( $dtFormat -> isYearMonth ( $args -> get ( $x ))) {
if ( $datequery ) {
$datequery2 = Strings :: escapeHtml ( $args -> get ( $x ));
} else {
$datequery = Strings :: escapeHtml ( $args -> get ( $x ));
}
} else {
$category = $args -> get ( $x );
}
}
}
if ( empty ( $category )) {
$category = $_GET [ 'category' ] ? ? '' ;
}
$hashtags = $_GET [ 'tag' ] ? ? '' ;
2019-11-03 02:19:42 +01:00
if ( DI :: config () -> get ( 'system' , 'block_public' ) && ! local_user () && ! Session :: getRemoteContactID ( $a -> profile [ 'uid' ])) {
2019-10-27 15:08:14 +01:00
return Login :: form ();
}
$o = '' ;
2019-11-03 02:19:42 +01:00
if ( $a -> profile [ 'uid' ] == local_user ()) {
2019-10-27 15:08:14 +01:00
Nav :: setSelected ( 'home' );
}
2019-11-03 02:19:42 +01:00
$remote_contact = Session :: getRemoteContactID ( $a -> profile [ 'uid' ]);
$is_owner = local_user () == $a -> profile [ 'uid' ];
$last_updated_key = " profile: " . $a -> profile [ 'uid' ] . " : " . local_user () . " : " . $remote_contact ;
2019-10-27 15:08:14 +01:00
if ( ! empty ( $a -> profile [ 'hidewall' ]) && ! $is_owner && ! $remote_contact ) {
notice ( DI :: l10n () -> t ( 'Access to this profile has been restricted.' ) . EOL );
return '' ;
}
2020-01-26 15:49:11 +01:00
$o .= self :: getTabsHTML ( $a , 'status' , $is_owner , $a -> profile [ 'nickname' ]);
2019-10-27 15:08:14 +01:00
2019-11-03 02:19:42 +01:00
$o .= Widget :: commonFriendsVisitor ( $a -> profile [ 'uid' ]);
2019-10-27 15:08:14 +01:00
$commpage = $a -> profile [ 'page-flags' ] == User :: PAGE_FLAGS_COMMUNITY ;
$commvisitor = $commpage && $remote_contact ;
DI :: page ()[ 'aside' ] .= Widget :: postedByYear ( DI :: baseUrl () . '/profile/' . $a -> profile [ 'nickname' ] . '/status' , $a -> profile [ 'profile_uid' ] ? ? 0 , true );
DI :: page ()[ 'aside' ] .= Widget :: categories ( DI :: baseUrl () . '/profile/' . $a -> profile [ 'nickname' ] . '/status' , XML :: escape ( $category ));
DI :: page ()[ 'aside' ] .= Widget :: tagCloud ();
2019-11-03 02:19:42 +01:00
if ( Security :: canWriteToUserWall ( $a -> profile [ 'uid' ])) {
2019-10-27 15:08:14 +01:00
$x = [
'is_owner' => $is_owner ,
'allow_location' => ( $is_owner || $commvisitor ) && $a -> profile [ 'allow_location' ],
'default_location' => $is_owner ? $a -> user [ 'default-location' ] : '' ,
'nickname' => $a -> profile [ 'nickname' ],
'lockstate' => is_array ( $a -> user )
&& ( strlen ( $a -> user [ 'allow_cid' ])
|| strlen ( $a -> user [ 'allow_gid' ])
|| strlen ( $a -> user [ 'deny_cid' ])
|| strlen ( $a -> user [ 'deny_gid' ])
) ? 'lock' : 'unlock' ,
'acl' => $is_owner ? ACL :: getFullSelectorHTML ( DI :: page (), $a -> user , true ) : '' ,
'bang' => '' ,
'visitor' => $is_owner || $commvisitor ? 'block' : 'none' ,
2019-11-03 02:19:42 +01:00
'profile_uid' => $a -> profile [ 'uid' ],
2019-10-27 15:08:14 +01:00
];
$o .= status_editor ( $a , $x );
}
// Get permissions SQL - if $remote_contact is true, our remote user has been pre-verified and we already have fetched his/her groups
2019-11-03 02:19:42 +01:00
$sql_extra = Item :: getPermissionsSQLByUserId ( $a -> profile [ 'uid' ]);
2019-10-27 15:08:14 +01:00
$sql_extra2 = '' ;
$last_updated_array = Session :: get ( 'last_updated' , []);
$sql_post_table = " " ;
if ( ! empty ( $category )) {
$sql_post_table = sprintf ( " INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` = %d ORDER BY `tid` DESC) AS `term` ON `item`.`id` = `term`.`oid` " ,
2019-11-03 02:19:42 +01:00
DBA :: escape ( Strings :: protectSprintf ( $category )), intval ( TERM_OBJ_POST ), intval ( TERM_CATEGORY ), intval ( $a -> profile [ 'uid' ]));
2019-10-27 15:08:14 +01:00
}
if ( ! empty ( $hashtags )) {
$sql_post_table .= sprintf ( " INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` = %d ORDER BY `tid` DESC) AS `term` ON `item`.`id` = `term`.`oid` " ,
2019-11-03 02:19:42 +01:00
DBA :: escape ( Strings :: protectSprintf ( $hashtags )), intval ( TERM_OBJ_POST ), intval ( TERM_HASHTAG ), intval ( $a -> profile [ 'uid' ]));
2019-10-27 15:08:14 +01:00
}
if ( ! empty ( $datequery )) {
$sql_extra2 .= Strings :: protectSprintf ( sprintf ( " AND `thread`.`received` <= '%s' " , DBA :: escape ( DateTimeFormat :: convert ( $datequery , 'UTC' , date_default_timezone_get ()))));
}
if ( ! empty ( $datequery2 )) {
$sql_extra2 .= Strings :: protectSprintf ( sprintf ( " AND `thread`.`received` >= '%s' " , DBA :: escape ( DateTimeFormat :: convert ( $datequery2 , 'UTC' , date_default_timezone_get ()))));
}
// Does the profile page belong to a forum?
// If not then we can improve the performance with an additional condition
2019-11-03 02:19:42 +01:00
$condition = [ 'uid' => $a -> profile [ 'uid' ], 'page-flags' => [ User :: PAGE_FLAGS_COMMUNITY , User :: PAGE_FLAGS_PRVGROUP ]];
2019-10-27 15:08:14 +01:00
if ( ! DBA :: exists ( 'user' , $condition )) {
$sql_extra3 = sprintf ( " AND `thread`.`contact-id` = %d " , intval ( intval ( $a -> profile [ 'contact_id' ])));
} else {
$sql_extra3 = " " ;
}
// check if we serve a mobile device and get the user settings
// accordingly
if ( DI :: mode () -> isMobile ()) {
$itemspage_network = DI :: pConfig () -> get ( local_user (), 'system' , 'itemspage_mobile_network' , 10 );
} else {
$itemspage_network = DI :: pConfig () -> get ( local_user (), 'system' , 'itemspage_network' , 20 );
}
// now that we have the user settings, see if the theme forces
// a maximum item number which is lower then the user choice
if (( $a -> force_max_items > 0 ) && ( $a -> force_max_items < $itemspage_network )) {
$itemspage_network = $a -> force_max_items ;
}
$pager = new Pager ( $args -> getQueryString (), $itemspage_network );
$pager_sql = sprintf ( " LIMIT %d, %d " , $pager -> getStart (), $pager -> getItemsPerPage ());
$items_stmt = DBA :: p (
" SELECT `item`.`uri`
FROM `thread`
STRAIGHT_JOIN `item` ON `item` . `id` = `thread` . `iid`
$sql_post_table
STRAIGHT_JOIN `contact`
ON `contact` . `id` = `thread` . `contact-id`
AND NOT `contact` . `blocked`
AND NOT `contact` . `pending`
WHERE `thread` . `uid` = ?
AND `thread` . `visible`
AND NOT `thread` . `deleted`
AND NOT `thread` . `moderated`
AND `thread` . `wall`
$sql_extra3
$sql_extra
$sql_extra2
ORDER BY `thread` . `received` DESC
$pager_sql " ,
2019-11-03 02:19:42 +01:00
$a -> profile [ 'uid' ]
2019-10-27 15:08:14 +01:00
);
// Set a time stamp for this page. We will make use of it when we
// search for new items (update routine)
$last_updated_array [ $last_updated_key ] = time ();
Session :: set ( 'last_updated' , $last_updated_array );
if ( $is_owner && ! DI :: config () -> get ( 'theme' , 'hide_eventlist' )) {
$o .= ProfileModel :: getBirthdays ();
$o .= ProfileModel :: getEventsReminderHTML ();
}
if ( $is_owner ) {
$unseen = Item :: exists ([ 'wall' => true , 'unseen' => true , 'uid' => local_user ()]);
if ( $unseen ) {
Item :: update ([ 'unseen' => false ], [ 'wall' => true , 'unseen' => true , 'uid' => local_user ()]);
}
}
$items = DBA :: toArray ( $items_stmt );
2020-01-26 20:14:36 +01:00
if ( $pager -> getStart () == 0 && ! empty ( $a -> profile [ 'uid' ])) {
$pinned_items = Item :: selectPinned ( $a -> profile [ 'uid' ], [ 'uri' , 'pinned' ]);
$pinned = Item :: inArray ( $pinned_items );
$items = array_merge ( $items , $pinned );
}
$o .= conversation ( $a , $items , $pager , 'profile' , false , false , 'pinned_received' , $a -> profile [ 'uid' ]);
2019-10-27 15:08:14 +01:00
$o .= $pager -> renderMinimal ( count ( $items ));
return $o ;
}
}