2010-07-20 01:52:31 -04:00
< ? php
2011-07-25 10:54:39 -04:00
require_once ( " include/datetime.php " );
2010-07-20 01:52:31 -04:00
function ping_init ( & $a ) {
if ( ! local_user ())
xml_status ( 0 );
2011-07-25 10:54:39 -04:00
2010-07-20 01:52:31 -04:00
$r = q ( " SELECT COUNT(*) AS `total` FROM `item`
2011-05-31 20:35:24 -04:00
WHERE `unseen` = 1 AND `visible` = 1 AND `deleted` = 0 AND `uid` = % d AND `wall` = 0 " ,
2010-10-18 17:34:59 -04:00
intval ( local_user ())
2010-07-20 01:52:31 -04:00
);
$network = $r [ 0 ][ 'total' ];
$r = q ( " SELECT COUNT(*) AS `total` FROM `item`
2011-05-20 04:15:02 -04:00
WHERE `unseen` = 1 AND `visible` = 1 AND `deleted` = 0 AND `uid` = % d AND `wall` = 1 " ,
2010-10-18 17:34:59 -04:00
intval ( local_user ())
2010-07-20 01:52:31 -04:00
);
$home = $r [ 0 ][ 'total' ];
2011-08-17 15:59:06 -04:00
$intros1 = q ( " SELECT COUNT(`intro`.`id`) AS `total`, `intro`.`id`, `intro`.`datetime`,
2011-07-25 10:54:39 -04:00
`fcontact` . `name` , `fcontact` . `url` , `fcontact` . `photo`
FROM `intro` LEFT JOIN `fcontact` ON `intro` . `fid` = `fcontact` . `id`
2011-08-17 15:59:06 -04:00
WHERE `intro` . `uid` = % d AND `intro` . `blocked` = 0 AND `intro` . `ignore` = 0 AND `intro` . `fid` != 0 " ,
2010-10-18 17:34:59 -04:00
intval ( local_user ())
2010-07-20 01:52:31 -04:00
);
2011-08-17 15:59:06 -04:00
$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 ;
2010-07-20 01:52:31 -04:00
2010-10-30 16:25:37 -04:00
$myurl = $a -> get_baseurl () . '/profile/' . $a -> user [ 'nickname' ] ;
2011-07-25 10:54:39 -04:00
$mails = q ( " SELECT *, COUNT(*) AS `total` FROM `mail`
2010-07-31 00:22:52 -04:00
WHERE `uid` = % d AND `seen` = 0 AND `from-url` != '%s' " ,
2010-10-18 17:34:59 -04:00
intval ( local_user ()),
2010-07-31 00:22:52 -04:00
dbesc ( $myurl )
);
2011-07-25 10:54:39 -04:00
$mail = $mails [ 0 ][ 'total' ];
2011-07-29 10:24:09 -04: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' ];
} else {
$register = " 0 " ;
}
$notsxml = '<note href="%s" name="%s" url="%s" photo="%s" date="%s">%s</note>' ;
2011-07-25 10:54:39 -04:00
2010-07-31 00:22:52 -04:00
2010-07-20 01:52:31 -04:00
header ( " Content-type: text/xml " );
2011-07-25 10:54:39 -04:00
echo " <?xml version= \" 1.0 \" encoding= \" UTF-8 \" ?>
< result >
< intro > $intro </ intro >
< mail > $mail </ mail >
< net > $network </ net >
2011-07-29 10:24:09 -04:00
< home > $home </ home > " ;
if ( $register != 0 ) echo " <register> $register </register> " ;
echo ' <notif count="' . ( $mail + $intro + $register ) . '">' ;
2011-07-25 10:54:39 -04:00
if ( $intro > 0 ){
foreach ( $intros as $i ) {
2011-07-29 10:24:09 -04:00
echo sprintf ( $notsxml ,
2011-08-17 15:59:06 -04:00
$a -> get_baseurl () . '/notifications/' . $i [ 'id' ], $i [ 'name' ], $i [ 'url' ], $i [ 'photo' ], relative_date ( $i [ 'datetime' ]), t ( " { 0} wants to be your friend " )
2011-07-25 10:54:39 -04:00
);
};
}
if ( $mail > 0 ){
foreach ( $mails as $i ) {
2011-07-29 10:24:09 -04:00
echo sprintf ( $notsxml ,
2011-07-25 10:54:39 -04:00
$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 " )
);
};
}
2011-07-29 10:24:09 -04:00
if ( $register > 0 ){
foreach ( $regs as $i ) {
echo sprintf ( $notsxml ,
$a -> get_baseurl () . '/admin/users/' , $i [ 'name' ], $i [ 'url' ], $i [ 'micro' ], relative_date ( $i [ 'created' ]), t ( " { 0} requested registration " )
);
};
}
2011-07-25 10:54:39 -04:00
echo " </notif>
</ result >
" ;
2010-07-20 01:52:31 -04:00
killme ();
}