2010-07-20 07:52:31 +02:00
< ? php
2011-07-25 16:54:39 +02:00
require_once ( " include/datetime.php " );
2010-07-20 07:52:31 +02:00
function ping_init ( & $a ) {
2011-09-28 09:30:22 +02:00
header ( " Content-type: text/xml " );
echo " <?xml version= \" 1.0 \" encoding= \" UTF-8 \" ?>
< result > " ;
2011-11-15 17:41:51 +01:00
$xmlhead = " < " . " ?xml version='1.0' encoding='UTF-8' ? " . " > " ;
2011-09-28 09:30:22 +02:00
if ( local_user ()){
2011-11-15 17:41:51 +01:00
$tags = array ();
2011-09-28 09:30:22 +02:00
$comments = array ();
$likes = array ();
$dislikes = array ();
$friends = array ();
2011-10-09 06:24:16 +02:00
$posts = array ();
2011-09-28 09:30:22 +02:00
2011-12-01 02:08:16 +01:00
2011-09-28 09:30:22 +02:00
$r = q ( " SELECT `item`.`id`,`item`.`parent`, `item`.`verb`, `item`.`author-name`,
2012-01-05 03:03:09 +01:00
`item` . `author-link` , `item` . `author-avatar` , `item` . `created` , `item` . `object` ,
2011-09-28 09:30:22 +02:00
`pitem` . `author-name` as `pname` , `pitem` . `author-link` as `plink`
FROM `item` INNER JOIN `item` as `pitem` ON `pitem` . `id` = `item` . `parent`
WHERE `item` . `unseen` = 1 AND `item` . `visible` = 1 AND
2011-12-01 02:08:16 +01:00
`item` . `deleted` = 0 AND `item` . `uid` = % d AND `item` . `wall` = 0
ORDER BY `item` . `created` DESC " ,
2011-09-28 09:30:22 +02:00
intval ( local_user ())
);
$network = count ( $r );
foreach ( $r as $it ) {
switch ( $it [ 'verb' ]){
2011-11-15 17:41:51 +01:00
case ACTIVITY_TAG :
$obj = parse_xml_string ( $xmlhead . $it [ 'object' ]);
$it [ 'tname' ] = $obj -> content ;
$tags [] = $it ;
break ;
2011-09-28 09:30:22 +02:00
case ACTIVITY_LIKE :
$likes [] = $it ;
break ;
case ACTIVITY_DISLIKE :
$dislikes [] = $it ;
break ;
case ACTIVITY_FRIEND :
$obj = parse_xml_string ( $xmlhead . $it [ 'object' ]);
$it [ 'fname' ] = $obj -> title ;
$friends [] = $it ;
break ;
default :
2011-11-14 12:09:11 +01:00
if ( $it [ 'parent' ] != $it [ 'id' ]) {
$comments [] = $it ;
} else {
$posts [] = $it ;
}
2011-09-28 09:30:22 +02:00
}
2011-08-23 13:52:20 +02:00
}
2010-07-20 07:52:31 +02:00
2011-09-28 09:30:22 +02:00
$r = q ( " SELECT `item`.`id`,`item`.`parent`, `item`.`verb`, `item`.`author-name`,
`item` . `author-link` , `item` . `author-avatar` , `item` . `created` , `item` . `object` ,
`pitem` . `author-name` as `pname` , `pitem` . `author-link` as `plink`
FROM `item` INNER JOIN `item` as `pitem` ON `pitem` . `id` = `item` . `parent`
WHERE `item` . `unseen` = 1 AND `item` . `visible` = 1 AND
`item` . `deleted` = 0 AND `item` . `uid` = % d AND `item` . `wall` = 1 " ,
intval ( local_user ())
);
$home = count ( $r );
foreach ( $r as $it ) {
switch ( $it [ 'verb' ]){
2011-11-15 17:41:51 +01:00
case ACTIVITY_TAG :
$obj = parse_xml_string ( $xmlhead . $it [ 'object' ]);
$it [ 'tname' ] = $obj -> content ;
$tags [] = $it ;
break ;
2011-09-28 09:30:22 +02:00
case ACTIVITY_LIKE :
$likes [] = $it ;
break ;
case ACTIVITY_DISLIKE :
$dislikes [] = $it ;
break ;
case ACTIVITY_FRIEND :
$obj = parse_xml_string ( $xmlhead . $it [ 'object' ]);
$it [ 'fname' ] = $obj -> title ;
$friends [] = $it ;
break ;
default :
if ( $it [ 'parent' ] != $it [ 'id' ]) $comments [] = $it ;
}
2011-08-23 13:52:20 +02:00
}
2010-07-20 07:52:31 +02:00
2011-09-28 09:30:22 +02:00
$intros1 = q ( " SELECT COUNT(`intro`.`id`) AS `total`, `intro`.`id`, `intro`.`datetime`,
`fcontact` . `name` , `fcontact` . `url` , `fcontact` . `photo`
FROM `intro` LEFT JOIN `fcontact` ON `intro` . `fid` = `fcontact` . `id`
WHERE `intro` . `uid` = % d AND `intro` . `blocked` = 0 AND `intro` . `ignore` = 0 AND `intro` . `fid` != 0 " ,
intval ( local_user ())
);
$intros2 = q ( " SELECT COUNT(`intro`.`id`) AS `total`, `intro`.`id`, `intro`.`datetime`,
`contact` . `name` , `contact` . `url` , `contact` . `photo`
FROM `intro` LEFT JOIN `contact` ON `intro` . `contact-id` = `contact` . `id`
WHERE `intro` . `uid` = % d AND `intro` . `blocked` = 0 AND `intro` . `ignore` = 0 AND `intro` . `contact-id` != 0 " ,
intval ( local_user ())
);
$intro = $intros1 [ 0 ][ 'total' ] + $intros2 [ 0 ][ 'total' ];
if ( $intros1 [ 0 ][ 'total' ] == 0 ) $intros1 = Array ();
if ( $intros2 [ 0 ][ 'total' ] == 0 ) $intros2 = Array ();
$intros = $intros1 + $intros2 ;
$myurl = $a -> get_baseurl () . '/profile/' . $a -> user [ 'nickname' ] ;
$mails = q ( " SELECT *, COUNT(*) AS `total` FROM `mail`
WHERE `uid` = % d AND `seen` = 0 AND `from-url` != '%s' " ,
intval ( local_user ()),
dbesc ( $myurl )
);
$mail = $mails [ 0 ][ 'total' ];
2012-01-05 03:03:09 +01:00
if ( $a -> config [ 'register_policy' ] == REGISTER_APPROVE && is_site_admin ()){
$regs = q ( " SELECT `contact`.`name`, `contact`.`url`, `contact`.`micro`, `register`.`created`, COUNT(*) as `total` FROM `contact` RIGHT JOIN `register` ON `register`.`uid`=`contact`.`uid` WHERE `contact`.`self`=1 " );
$register = $regs [ 0 ][ 'total' ];
2011-09-28 09:30:22 +02:00
} else {
$register = " 0 " ;
}
2011-08-17 21:59:06 +02:00
2010-07-20 07:52:31 +02:00
2011-09-28 09:30:22 +02:00
function xmlize ( $href , $name , $url , $photo , $date , $message ){
$notsxml = '<note href="%s" name="%s" url="%s" photo="%s" date="%s">%s</note>' ;
return sprintf ( $notsxml ,
2011-10-09 07:02:24 +02:00
xmlify ( $href ), xmlify ( $name ), xmlify ( $url ), xmlify ( $photo ), xmlify ( $date ), xmlify ( $message )
2011-09-28 09:30:22 +02:00
);
}
echo " <intro> $intro </intro>
< mail > $mail </ mail >
< net > $network </ net >
< home > $home </ home > " ;
if ( $register != 0 ) echo " <register> $register </register> " ;
2012-01-05 03:03:09 +01:00
$tot = $mail + $intro + $register + count ( $comments ) + count ( $likes ) + count ( $dislikes ) + count ( $friends ) + count ( $posts ) + count ( $tags );
2011-09-28 09:30:22 +02:00
echo ' <notif count="' . $tot . '">' ;
if ( $intro > 0 ){
foreach ( $intros as $i ) {
2012-01-05 03:03:09 +01:00
echo xmlize ( $a -> get_baseurl () . '/notifications/' . $i [ 'id' ], $i [ 'name' ], $i [ 'url' ], $i [ 'photo' ], relative_date ( $i [ 'datetime' ]), t ( " { 0} wants to be your friend " ) );
2011-09-28 09:30:22 +02:00
};
}
if ( $mail > 0 ){
foreach ( $mails as $i ) {
echo xmlize ( $a -> get_baseurl () . '/message/' . $i [ 'id' ], $i [ 'from-name' ], $i [ 'from-url' ], $i [ 'from-photo' ], relative_date ( $i [ 'created' ]), t ( " { 0} sent you a message " ) );
};
}
if ( $register > 0 ){
foreach ( $regs as $i ) {
echo xmlize ( $a -> get_baseurl () . '/admin/users/' , $i [ 'name' ], $i [ 'url' ], $i [ 'micro' ], relative_date ( $i [ 'created' ]), t ( " { 0} requested registration " ) );
};
}
2011-07-29 16:24:09 +02:00
2011-09-28 09:30:22 +02:00
if ( count ( $comments )){
foreach ( $comments as $i ) {
echo xmlize ( $a -> get_baseurl () . '/display/' . $a -> user [ 'nickname' ] . " / " . $i [ 'parent' ], $i [ 'author-name' ], $i [ 'author-link' ], $i [ 'author-avatar' ], relative_date ( $i [ 'created' ]), sprintf ( t ( " { 0} commented %s's post " ), $i [ 'pname' ] ) );
};
}
if ( count ( $likes )){
foreach ( $likes as $i ) {
2011-10-09 06:24:16 +02:00
echo xmlize ( $a -> get_baseurl () . '/display/' . $a -> user [ 'nickname' ] . " / " . $i [ 'parent' ], $i [ 'author-name' ], $i [ 'author-link' ], $i [ 'author-avatar' ], relative_date ( $i [ 'created' ]), sprintf ( t ( " { 0} liked %s's post " ), $i [ 'pname' ] ) );
2011-09-28 09:30:22 +02:00
};
}
if ( count ( $dislikes )){
foreach ( $dislikes as $i ) {
2011-10-09 06:24:16 +02:00
echo xmlize ( $a -> get_baseurl () . '/display/' . $a -> user [ 'nickname' ] . " / " . $i [ 'parent' ], $i [ 'author-name' ], $i [ 'author-link' ], $i [ 'author-avatar' ], relative_date ( $i [ 'created' ]), sprintf ( t ( " { 0} disliked %s's post " ), $i [ 'pname' ] ) );
2011-09-28 09:30:22 +02:00
};
}
if ( count ( $friends )){
foreach ( $friends as $i ) {
2011-10-13 10:12:03 +02:00
echo xmlize ( $a -> get_baseurl () . '/display/' . $a -> user [ 'nickname' ] . " / " . $i [ 'parent' ], $i [ 'author-name' ], $i [ 'author-link' ], $i [ 'author-avatar' ], relative_date ( $i [ 'created' ]), sprintf ( t ( " { 0} is now friends with %s " ), $i [ 'fname' ] ) );
2011-10-09 06:24:16 +02:00
};
}
if ( count ( $posts )){
foreach ( $posts as $i ) {
2012-01-05 03:03:09 +01:00
echo xmlize ( $a -> get_baseurl () . '/display/' . $a -> user [ 'nickname' ] . " / " . $i [ 'parent' ], $i [ 'author-name' ], $i [ 'author-link' ], $i [ 'author-avatar' ], relative_date ( $i [ 'created' ]), sprintf ( t ( " { 0} posted " ) ) );
2011-09-28 09:30:22 +02:00
};
}
2011-11-15 17:41:51 +01:00
if ( count ( $tags )){
foreach ( $tags as $i ) {
echo xmlize ( $a -> get_baseurl () . '/display/' . $a -> user [ 'nickname' ] . " / " . $i [ 'parent' ], $i [ 'author-name' ], $i [ 'author-link' ], $i [ 'author-avatar' ], relative_date ( $i [ 'created' ]), sprintf ( t ( " { 0} tagged %s's post with #%s " ), $i [ 'pname' ], $i [ 'tname' ] ) );
};
}
2011-08-23 13:52:20 +02:00
2011-09-28 09:30:22 +02:00
echo " </notif> " ;
2011-07-29 16:24:09 +02:00
}
2011-09-05 14:01:21 +02:00
echo " <sysmsgs> " ;
2011-09-28 09:30:22 +02:00
2011-09-05 14:01:21 +02:00
if ( x ( $_SESSION , 'sysmsg' )){
foreach ( $_SESSION [ 'sysmsg' ] as $m ){
2011-10-12 03:24:37 +02:00
echo " <notice> " . xmlify ( $m ) . " </notice> " ;
2011-09-05 14:01:21 +02:00
}
unset ( $_SESSION [ 'sysmsg' ]);
}
if ( x ( $_SESSION , 'sysmsg_info' )){
foreach ( $_SESSION [ 'sysmsg_info' ] as $m ){
2011-10-12 03:24:37 +02:00
echo " <info> " . xmlify ( $m ) . " </info> " ;
2011-09-05 14:01:21 +02:00
}
unset ( $_SESSION [ 'sysmsg_info' ]);
}
echo " </sysmsgs> " ;
echo " </result>
2011-07-25 16:54:39 +02:00
" ;
2010-07-20 07:52:31 +02:00
killme ();
}