Introduced common_location_shared() to check if location sharing is always,
[quix0rs-gnu-social.git] / plugins / OStatus / lib / huboutqueuehandler.php
1 <?php
2 /*
3  * StatusNet - the distributed open-source microblogging tool
4  * Copyright (C) 2010, StatusNet, Inc.
5  *
6  * This program is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU Affero General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU Affero General Public License for more details.
15  *
16  * You should have received a copy of the GNU Affero General Public License
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20 if (!defined('STATUSNET')) {
21     exit(1);
22 }
23
24 /**
25  * Send a raw PuSH atom update from our internal hub.
26  * @package Hub
27  * @author Brion Vibber <brion@status.net>
28  */
29 class HubOutQueueHandler extends QueueHandler
30 {
31     function transport()
32     {
33         return 'hubout';
34     }
35
36     function handle($data)
37     {
38         $sub = $data['sub'];
39         $atom = $data['atom'];
40         $retries = $data['retries'];
41
42         assert($sub instanceof HubSub);
43         assert(is_string($atom));
44
45         try {
46             $sub->push($atom);
47         } catch (Exception $e) {
48             $retries--;
49             $msg = "Failed PuSH to $sub->callback for $sub->topic: " .
50                    $e->getMessage();
51             if ($retries > 0) {
52                 common_log(LOG_INFO, "$msg; scheduling for $retries more tries");
53
54                 // @fixme when we have infrastructure to schedule a retry
55                 // after a delay, use it.
56                 $sub->distribute($atom, $retries);
57             } else {
58                 common_log(LOG_ERR, "$msg; discarding");
59             }
60         }
61
62         return true;
63     }
64 }