2017-11-19 12:36:20 -05:00
< ? php
/**
* @ file src / Worker / PubSubPublish . php
*/
namespace Friendica\Worker ;
2018-07-19 22:15:21 -04:00
use Friendica\BaseObject ;
2017-11-19 12:36:20 -05: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 ;
2017-11-19 12:36:20 -05:00
use Friendica\Protocol\OStatus ;
2018-01-26 23:24:23 -05:00
use Friendica\Util\Network ;
2017-11-19 12:36:20 -05:00
require_once 'include/items.php' ;
2018-07-09 22:39:59 -04:00
class PubSubPublish
{
2017-11-19 12:36:20 -05:00
public static function execute ( $pubsubpublish_id = 0 )
{
2018-05-17 19:30:49 -04:00
if ( $pubsubpublish_id == 0 ) {
2018-05-17 18:17:03 -04:00
return ;
2017-11-19 12:36:20 -05:00
}
2018-05-17 19:30:49 -04:00
self :: publish ( $pubsubpublish_id );
2017-11-19 12:36:20 -05:00
}
2018-07-09 22:39:59 -04:00
private static function publish ( $id )
{
2018-07-19 22:15:21 -04:00
$a = BaseObject :: getApp ();
2017-11-19 12:36:20 -05:00
2018-07-20 08:19:26 -04:00
$subscriber = DBA :: selectFirst ( 'push_subscriber' , [], [ 'id' => $id ]);
2018-07-21 08:40:21 -04:00
if ( ! DBA :: is_result ( $subscriber )) {
2017-11-19 12:36:20 -05: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-05-17 18:17:03 -04:00
logger ( " Generate feed of user " . $subscriber [ 'nickname' ] . " to " . $subscriber [ 'callback_url' ] . " - last updated " . $subscriber [ 'last_update' ], LOGGER_DEBUG );
2017-11-19 12:36:20 -05:00
2018-05-17 18:17:03 -04:00
$last_update = $subscriber [ 'last_update' ];
$params = OStatus :: feed ( $subscriber [ 'nickname' ], $last_update );
2017-11-19 12:36:20 -05:00
if ( ! $params ) {
return ;
}
2018-05-17 18:17:03 -04:00
$hmac_sig = hash_hmac ( " sha1 " , $params , $subscriber [ 'secret' ]);
2017-11-19 12:36:20 -05:00
2018-01-15 08:05:12 -05:00
$headers = [ " Content-type: application/atom+xml " ,
2017-11-19 12:36:20 -05:00
sprintf ( " Link: <%s>;rel=hub,<%s>;rel=self " ,
2018-05-17 18:17:03 -04:00
System :: baseUrl () . '/pubsubhubbub/' . $subscriber [ 'nickname' ],
$subscriber [ 'topic' ]),
" X-Hub-Signature: sha1= " . $hmac_sig ];
2017-11-19 12:36:20 -05:00
2018-05-17 18:17:03 -04:00
logger ( 'POST ' . print_r ( $headers , true ) . " \n " . $params , LOGGER_DATA );
2017-11-19 12:36:20 -05:00
2018-05-17 18:17:03 -04:00
Network :: post ( $subscriber [ 'callback_url' ], $params , $headers );
2017-11-19 12:36:20 -05:00
$ret = $a -> get_curl_code ();
2018-05-17 18:17:03 -04:00
$condition = [ 'id' => $subscriber [ 'id' ]];
2017-11-19 12:36:20 -05:00
if ( $ret >= 200 && $ret <= 299 ) {
2018-05-17 18:17:03 -04:00
logger ( 'Successfully pushed to ' . $subscriber [ 'callback_url' ]);
2017-11-19 12:36:20 -05:00
2018-05-18 23:56:29 -04:00
PushSubscriber :: reset ( $subscriber [ 'id' ], $last_update );
2017-11-19 12:36:20 -05:00
} else {
2018-05-17 18:17:03 -04:00
logger ( 'Delivery error when pushing to ' . $subscriber [ 'callback_url' ] . ' HTTP: ' . $ret );
2017-11-19 12:36:20 -05:00
2018-05-18 23:56:29 -04:00
PushSubscriber :: delay ( $subscriber [ 'id' ]);
2017-11-19 12:36:20 -05:00
}
}
}