2017-11-19 17:36:20 +00:00
< ? php
/**
* @ file src / Worker / PubSubPublish . php
*/
namespace Friendica\Worker ;
2018-10-29 17:20:46 -04:00
use Friendica\Core\Logger ;
2017-11-19 17:36:20 +00:00
use Friendica\Core\System ;
2018-07-20 08:19:26 -04:00
use Friendica\Database\DBA ;
2018-07-19 22:15:21 -04:00
use Friendica\Model\PushSubscriber ;
2019-10-03 23:33:41 +00:00
use Friendica\Model\GServer ;
2017-11-19 17:36:20 +00:00
use Friendica\Protocol\OStatus ;
2018-01-26 23:24:23 -05:00
use Friendica\Util\Network ;
2017-11-19 17:36:20 +00:00
2018-07-09 22:39:59 -04: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-09 22:39:59 -04:00
private static function publish ( $id )
{
2018-07-20 08:19:26 -04:00
$subscriber = DBA :: selectFirst ( 'push_subscriber' , [], [ 'id' => $id ]);
2018-07-21 08:46:04 -04:00
if ( ! DBA :: isResult ( $subscriber )) {
2017-11-19 17:36:20 +00:00
return ;
}
2019-10-03 23:33:41 +00:00
/// @todo Check server status with GServer::check()
2017-11-19 17:36:20 +00:00
// Before this can be done we need a way to safely detect the server url.
2018-10-30 09:58:45 -04: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 08:05:12 -05: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 09:58:45 -04:00
Logger :: log ( 'POST ' . print_r ( $headers , true ) . " \n " . $params , Logger :: DATA );
2017-11-19 17:36:20 +00:00
2018-10-10 21:15:26 +02:00
$postResult = Network :: post ( $subscriber [ 'callback_url' ], $params , $headers );
$ret = $postResult -> getReturnCode ();
2017-11-19 17:36:20 +00:00
if ( $ret >= 200 && $ret <= 299 ) {
2018-10-29 17:20:46 -04: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 17:20:46 -04: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
}
}
}