]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - plugins/OStatus/lib/hubconfqueuehandler.php
Merge branch 'testing' of git@gitorious.org:statusnet/mainline into testing
[quix0rs-gnu-social.git] / plugins / OStatus / lib / hubconfqueuehandler.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 /**
21  * Send a PuSH subscription verification from our internal hub.
22  * @package Hub
23  * @author Brion Vibber <brion@status.net>
24  */
25 class HubConfQueueHandler extends QueueHandler
26 {
27     function transport()
28     {
29         return 'hubconf';
30     }
31
32     function handle($data)
33     {
34         $sub = $data['sub'];
35         $mode = $data['mode'];
36         $token = $data['token'];
37
38         assert($sub instanceof HubSub);
39         assert($mode === 'subscribe' || $mode === 'unsubscribe');
40
41         common_log(LOG_INFO, __METHOD__ . ": $mode $sub->callback $sub->topic");
42         try {
43             $sub->verify($mode, $token);
44         } catch (Exception $e) {
45             common_log(LOG_ERR, "Failed PuSH $mode verify to $sub->callback for $sub->topic: " .
46                                 $e->getMessage());
47             // @fixme schedule retry?
48             // @fixme just kill it?
49         }
50
51         return true;
52     }
53 }
54