2010-07-01 23:48:07 +00:00
< ? php
function notifications_post ( & $a ) {
2010-08-16 04:49:29 +00:00
if ( ! local_user ()) {
2010-07-01 23:48:07 +00:00
goaway ( $a -> get_baseurl ());
}
2010-08-16 04:49:29 +00:00
$request_id = (( $a -> argc > 1 ) ? $a -> argv [ 1 ] : 0 );
2010-07-01 23:48:07 +00:00
2010-09-27 02:44:03 +00:00
if ( $request_id === " all " )
2010-07-01 23:48:07 +00:00
return ;
if ( $request_id ) {
2011-06-27 04:55:24 +00:00
$r = q ( " SELECT * FROM `intro` WHERE `id` = %d AND `uid` = %d LIMIT 1 " ,
intval ( $request_id ),
intval ( local_user ())
2010-07-01 23:48:07 +00:00
);
if ( count ( $r )) {
$intro_id = $r [ 0 ][ 'id' ];
2010-11-07 00:01:57 +00:00
$contact_id = $r [ 0 ][ 'contact-id' ];
2010-07-01 23:48:07 +00:00
}
else {
2010-08-16 04:49:29 +00:00
notice ( t ( 'Invalid request identifier.' ) . EOL );
2010-07-01 23:48:07 +00:00
return ;
}
2011-06-27 04:55:24 +00:00
// If it is a friend suggestion, the contact is not a new friend but an existing friend
// that should not be deleted.
$fid = $r [ 0 ][ 'fid' ];
2010-08-16 05:43:42 +00:00
if ( $_POST [ 'submit' ] == t ( 'Discard' )) {
2010-09-09 03:14:17 +00:00
$r = q ( " DELETE FROM `intro` WHERE `id` = %d LIMIT 1 " ,
intval ( $intro_id )
);
2011-06-27 04:55:24 +00:00
if ( ! $fid ) {
$r = q ( " DELETE FROM `contact` WHERE `id` = %d AND `uid` = %d AND `self` = 0 LIMIT 1 " ,
intval ( $contact_id ),
intval ( local_user ())
);
}
2010-07-01 23:48:07 +00:00
return ;
}
2010-08-16 04:49:29 +00:00
if ( $_POST [ 'submit' ] == t ( 'Ignore' )) {
2010-07-01 23:48:07 +00:00
$r = q ( " UPDATE `intro` SET `ignore` = 1 WHERE `id` = %d LIMIT 1 " ,
intval ( $intro_id ));
return ;
}
}
}
function notifications_content ( & $a ) {
2010-08-16 04:49:29 +00:00
if ( ! local_user ()) {
notice ( t ( 'Permission denied.' ) . EOL );
2010-07-01 23:48:07 +00:00
goaway ( $a -> get_baseurl ());
}
2010-08-16 04:49:29 +00:00
$o = '' ;
2010-09-19 04:11:18 +00:00
$o .= '<script> $(document).ready(function() { $(\'#nav-notify-link\').addClass(\'nav-selected\'); });</script>' ;
2010-08-16 04:49:29 +00:00
2010-07-01 23:48:07 +00:00
if (( $a -> argc > 1 ) && ( $a -> argv [ 1 ] == 'all' ))
$sql_extra = '' ;
else
$sql_extra = " AND `ignore` = 0 " ;
2011-03-30 00:19:12 +00:00
$o .= '<h1>' . t ( 'Pending Friend/Connect Notifications' ) . '</h1>' . " \r \n " ;
$o .= '<div id="notification-show-hide-wrapper" >' ;
$o .= '<a href="' . (( strlen ( $sql_extra )) ? 'notifications/all' : 'notifications' ) . '" id="notifications-show-hide-link" >'
. (( strlen ( $sql_extra )) ? t ( 'Show Ignored Requests' ) : t ( 'Hide Ignored Requests' )) . '</a></div>' . " \r \n " ;
2010-07-12 23:43:59 +00:00
2011-01-13 10:01:00 +00:00
$r = q ( " SELECT COUNT(*) AS `total` FROM `intro`
WHERE `intro` . `uid` = % d $sql_extra AND `intro` . `blocked` = 0 " ,
intval ( $_SESSION [ 'uid' ])
);
if ( $r && count ( $r )) {
$a -> set_pager_total ( $r [ 0 ][ 'total' ]);
$a -> set_pager_itemspage ( 20 );
}
2011-06-27 04:55:24 +00:00
$r = q ( " SELECT `intro`.`id` AS `intro_id`, `intro`.*, `contact`.*, `fcontact`.`name` AS `fname`,`fcontact`.`url` AS `furl`,`fcontact`.`photo` AS `fphoto`,`fcontact`.`request` AS `frequest`
FROM `intro` LEFT JOIN `contact` ON `contact` . `id` = `intro` . `contact-id` LEFT JOIN `fcontact` ON `intro` . `fid` = `fcontact` . `id`
2010-07-01 23:48:07 +00:00
WHERE `intro` . `uid` = % d $sql_extra AND `intro` . `blocked` = 0 " ,
intval ( $_SESSION [ 'uid' ]));
2010-07-12 23:43:59 +00:00
2010-07-01 23:48:07 +00:00
if (( $r !== false ) && ( count ( $r ))) {
2011-06-27 04:55:24 +00:00
$sugg = get_markup_template ( 'suggestions.tpl' );
2011-05-11 11:37:13 +00:00
$tpl = get_markup_template ( " intros.tpl " );
2010-07-01 23:48:07 +00:00
foreach ( $r as $rr ) {
2011-06-27 04:55:24 +00:00
if ( $rr [ 'fid' ]) {
2010-07-01 23:48:07 +00:00
2011-06-27 04:55:24 +00:00
$return_addr = bin2hex ( $a -> user [ 'nickname' ] . '@' . $a -> get_hostname () . (( $a -> path ) ? '/' . $a -> path : '' ));
$o .= replace_macros ( $sugg , array (
'$str_notifytype' => t ( 'Notification type: ' ),
'$notify_type' => t ( 'Friend Suggestion' ),
'$intro_id' => $rr [ 'intro_id' ],
'$madeby' => sprintf ( t ( 'suggested by %s' ), $rr [ 'name' ]),
'$contact_id' => $rr [ 'contact-id' ],
'$photo' => (( x ( $rr , 'fphoto' )) ? $rr [ 'fphoto' ] : " images/default-profile.jpg " ),
'$fullname' => $rr [ 'fname' ],
'$url' => $rr [ 'furl' ],
'$knowyou' => $knowyou ,
'$approve' => t ( 'Approve' ),
'$note' => $rr [ 'note' ],
'$request' => $rr [ 'frequest' ] . '?addr=' . $return_addr ,
'$ignore' => t ( 'Ignore' ),
'$discard' => t ( 'Discard' )
));
continue ;
}
2010-11-19 04:28:41 +00:00
$friend_selected = (( $rr [ 'network' ] !== 'stat' ) ? ' checked="checked" ' : ' disabled ' );
2010-10-25 03:39:24 +00:00
$fan_selected = (( $rr [ 'network' ] === 'stat' ) ? ' checked="checked" disabled ' : '' );
2011-05-11 11:37:13 +00:00
$dfrn_tpl = get_markup_template ( 'netfriend.tpl' );
2010-10-25 03:39:24 +00:00
$knowyou = '' ;
$dfrn_text = '' ;
2010-11-19 04:28:41 +00:00
if ( $rr [ 'network' ] !== 'stat' ) {
2010-10-25 03:39:24 +00:00
$knowyou = t ( 'Claims to be known to you: ' ) . (( $rr [ 'knowyou' ]) ? t ( 'yes' ) : t ( 'no' ));
$dfrn_text = replace_macros ( $dfrn_tpl , array (
'$intro_id' => $rr [ 'intro_id' ],
'$friend_selected' => $friend_selected ,
'$fan_selected' => $fan_selected ,
2011-02-22 23:35:33 +00:00
'$approve_as' => t ( 'Approve as: ' ),
'$as_friend' => t ( 'Friend' ),
'$as_fan' => t ( 'Fan/Admirer' )
2010-10-25 03:39:24 +00:00
));
}
2010-07-01 23:48:07 +00:00
$o .= replace_macros ( $tpl , array (
2010-11-16 07:27:12 +00:00
'$str_notifytype' => t ( 'Notification type: ' ),
2010-11-19 04:28:41 +00:00
'$notify_type' => (( $rr [ 'network' ] !== 'stat' ) ? t ( 'Friend/Connect Request' ) : t ( 'New Follower' )),
2010-10-25 03:39:24 +00:00
'$dfrn_text' => $dfrn_text ,
'$dfrn_id' => $rr [ 'issued-id' ],
2010-07-01 23:48:07 +00:00
'$uid' => $_SESSION [ 'uid' ],
2010-10-25 03:39:24 +00:00
'$intro_id' => $rr [ 'intro_id' ],
'$contact_id' => $rr [ 'contact-id' ],
2010-07-01 23:48:07 +00:00
'$photo' => (( x ( $rr , 'photo' )) ? $rr [ 'photo' ] : " images/default-profile.jpg " ),
'$fullname' => $rr [ 'name' ],
'$url' => $rr [ 'url' ],
2010-10-25 03:39:24 +00:00
'$knowyou' => $knowyou ,
2010-11-16 07:27:12 +00:00
'$approve' => t ( 'Approve' ),
2010-12-02 04:37:42 +00:00
'$note' => $rr [ 'note' ],
'$ignore' => t ( 'Ignore' ),
'$discard' => t ( 'Discard' )
2010-07-01 23:48:07 +00:00
));
}
}
else
2011-05-23 09:39:57 +00:00
info ( t ( 'No notifications.' ) . EOL );
2010-07-01 23:48:07 +00:00
2011-06-27 04:55:24 +00:00
/*
2011-01-05 07:31:51 +00:00
if ( $a -> config [ 'register_policy' ] == REGISTER_APPROVE &&
2011-01-05 06:17:58 +00:00
$a -> config [ 'admin_email' ] === $a -> user [ 'email' ]){
2011-03-30 00:19:12 +00:00
$o .= '<h1>' . t ( 'User registrations waiting for confirm' ) . '</h1>' . " \r \n " ;
2011-01-04 13:46:08 +00:00
$r = q ( " SELECT `register`.*, `contact`.`name`, `user`.`email`
FROM `register`
LEFT JOIN `contact` ON `register` . `uid` = `contact` . `uid`
LEFT JOIN `user` ON `register` . `uid` = `user` . `uid` ; " );
if (( $r !== false ) && ( count ( $r ))) {
2011-04-08 01:00:35 +00:00
$o .= '<ul>' ;
2011-01-04 13:46:08 +00:00
foreach ( $r as $rr ) {
2011-04-08 01:00:35 +00:00
$o .= '<li>' . sprintf ( '%s (%s) : ' , $rr [ 'name' ], $rr [ 'email' ])
. '<a href="regmod/allow/' . $rr [ 'hash' ] . '">' . t ( 'Approve' )
2011-05-20 22:11:36 +00:00
. '</a> - <a href="regmod/deny/' . $rr [ 'hash' ] . '">' . t ( 'Deny' ) . '</a></li>' . " \r \n " ;
2011-01-04 13:46:08 +00:00
}
2011-04-08 01:00:35 +00:00
$o .= " </ul> " ;
2011-01-04 13:46:08 +00:00
}
else
2011-05-23 09:39:57 +00:00
info ( t ( 'No registrations.' ) . EOL );
2011-01-04 13:46:08 +00:00
}
2011-06-27 04:55:24 +00:00
*/
2011-01-04 13:46:08 +00:00
2011-01-13 10:01:00 +00:00
$o .= paginate ( $a );
2010-07-01 23:48:07 +00:00
return $o ;
2011-01-04 13:46:08 +00:00
}