2017-11-19 17:36:20 +00:00
< ? php
/**
* @ file src / Worker / PubSubPublish . php
*/
namespace Friendica\Worker ;
2018-07-20 02:15:21 +00:00
use Friendica\BaseObject ;
2018-10-29 21:20:46 +00:00
use Friendica\Core\Logger ;
2017-11-19 17:36:20 +00:00
use Friendica\Core\System ;
2018-07-20 12:19:26 +00:00
use Friendica\Database\DBA ;
2018-07-20 02:15:21 +00:00
use Friendica\Model\PushSubscriber ;
2017-11-19 17:36:20 +00:00
use Friendica\Protocol\OStatus ;
2018-01-27 04:24:23 +00:00
use Friendica\Util\Network ;
2017-11-19 17:36:20 +00:00
require_once 'include/items.php' ;
2018-07-10 02:39:59 +00:00
class PubSubPublish
{
2017-11-19 17:36:20 +00:00
public static function execute ( $pubsubpublish_id = 0 )
{
2018-05-17 23:30:49 +00:00
if ( $pubsubpublish_id == 0 ) {
2018-05-17 22:17:03 +00:00
return ;
2017-11-19 17:36:20 +00:00
}
2018-05-17 23:30:49 +00:00
self :: publish ( $pubsubpublish_id );
2017-11-19 17:36:20 +00:00
}
2018-07-10 02:39:59 +00:00
private static function publish ( $id )
{
2018-07-20 02:15:21 +00:00
$a = BaseObject :: getApp ();
2017-11-19 17:36:20 +00:00
2018-07-20 12:19:26 +00:00
$subscriber = DBA :: selectFirst ( 'push_subscriber' , [], [ 'id' => $id ]);
2018-07-21 12:46:04 +00:00
if ( ! DBA :: isResult ( $subscriber )) {
2017-11-19 17:36:20 +00:00
return ;
}
/// @todo Check server status with PortableContact::checkServer()
// Before this can be done we need a way to safely detect the server url.
2018-10-30 13:58:45 +00:00
Logger :: log ( " Generate feed of user " . $subscriber [ 'nickname' ] . " to " . $subscriber [ 'callback_url' ] . " - last updated " . $subscriber [ 'last_update' ], Logger :: DEBUG );
2017-11-19 17:36:20 +00:00
2018-05-17 22:17:03 +00:00
$last_update = $subscriber [ 'last_update' ];
$params = OStatus :: feed ( $subscriber [ 'nickname' ], $last_update );
2017-11-19 17:36:20 +00:00
if ( ! $params ) {
return ;
}
2018-05-17 22:17:03 +00:00
$hmac_sig = hash_hmac ( " sha1 " , $params , $subscriber [ 'secret' ]);
2017-11-19 17:36:20 +00:00
2018-01-15 13:05:12 +00:00
$headers = [ " Content-type: application/atom+xml " ,
2017-11-19 17:36:20 +00:00
sprintf ( " Link: <%s>;rel=hub,<%s>;rel=self " ,
2018-05-17 22:17:03 +00:00
System :: baseUrl () . '/pubsubhubbub/' . $subscriber [ 'nickname' ],
$subscriber [ 'topic' ]),
" X-Hub-Signature: sha1= " . $hmac_sig ];
2017-11-19 17:36:20 +00:00
2018-10-30 13:58:45 +00:00
Logger :: log ( 'POST ' . print_r ( $headers , true ) . " \n " . $params , Logger :: DATA );
2017-11-19 17:36:20 +00:00
2018-10-10 19:15:26 +00:00
$postResult = Network :: post ( $subscriber [ 'callback_url' ], $params , $headers );
$ret = $postResult -> getReturnCode ();
2017-11-19 17:36:20 +00:00
2018-05-17 22:17:03 +00:00
$condition = [ 'id' => $subscriber [ 'id' ]];
2017-11-19 17:36:20 +00:00
if ( $ret >= 200 && $ret <= 299 ) {
2018-10-29 21:20:46 +00:00
Logger :: log ( 'Successfully pushed to ' . $subscriber [ 'callback_url' ]);
2017-11-19 17:36:20 +00:00
2018-05-19 03:56:29 +00:00
PushSubscriber :: reset ( $subscriber [ 'id' ], $last_update );
2017-11-19 17:36:20 +00:00
} else {
2018-10-29 21:20:46 +00:00
Logger :: log ( 'Delivery error when pushing to ' . $subscriber [ 'callback_url' ] . ' HTTP: ' . $ret );
2017-11-19 17:36:20 +00:00
2018-05-19 03:56:29 +00:00
PushSubscriber :: delay ( $subscriber [ 'id' ]);
2017-11-19 17:36:20 +00:00
}
}
}