2010-02-22 06:40:59 +09:00
< ? php
/*
* StatusNet - the distributed open - source microblogging tool
* Copyright ( C ) 2010 , StatusNet , Inc .
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU Affero General Public License for more details .
*
* You should have received a copy of the GNU Affero General Public License
* along with this program . If not , see < http :// www . gnu . org / licenses />.
*/
2017-04-26 03:42:10 +09:00
if ( ! defined ( 'GNUSOCIAL' )) { exit ( 1 ); }
2010-10-09 02:42:59 +09:00
2010-02-22 06:40:59 +09:00
/**
2017-05-01 18:04:27 +09:00
* Process a feed distribution POST from a WebSub ( previously PuSH ) hub .
2010-02-22 06:40:59 +09:00
* @ package FeedSub
* @ author Brion Vibber < brion @ status . net >
*/
2010-02-25 05:36:36 +09:00
class PushInQueueHandler extends QueueHandler
2010-02-22 06:40:59 +09:00
{
function transport ()
{
2010-02-25 05:36:36 +09:00
return 'pushin' ;
2010-02-22 06:40:59 +09:00
}
function handle ( $data )
{
assert ( is_array ( $data ));
$feedsub_id = $data [ 'feedsub_id' ];
$post = $data [ 'post' ];
$hmac = $data [ 'hmac' ];
2017-04-26 03:42:10 +09:00
try {
$feedsub = FeedSub :: getByID ( $feedsub_id );
$feedsub -> receive ( $post , $hmac );
} catch ( NoResultException $e ) {
common_log ( LOG_INFO , " Discarding POST to unknown feed subscription id { $feedsub_id } " );
} catch ( Exception $e ) {
2017-06-22 21:37:32 +09:00
if ( is_null ( $feedsub )) {
common_log ( LOG_ERR , " Exception " . _ve ( get_class ( $e )) . " during WebSub push input processing where FeedSub->receive returned null! " . _ve ( $e -> getMessage ()));
} else {
common_log ( LOG_ERR , " Exception " . _ve ( get_class ( $e )) . " during WebSub push input processing for { $feedsub -> getUri () } : " . _ve ( $e -> getMessage ()));
}
2010-02-22 06:40:59 +09:00
}
return true ;
}
}