]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - plugins/YammerImport/lib/yammerqueuehandler.php
Made YammerImport more robust against errors; can now pause/resume/reset the import...
[quix0rs-gnu-social.git] / plugins / YammerImport / lib / yammerqueuehandler.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  * Queue handler for bumping the next chunk of Yammer import activity!
26  *
27  * @package YammerImportPlugin
28  * @author Brion Vibber <brion@status.net>
29  */
30 class YammerQueueHandler extends QueueHandler
31 {
32     function transport()
33     {
34         return 'yammer';
35     }
36
37     function handle($notice)
38     {
39         $runner = YammerRunner::init();
40         if ($runner->hasWork()) {
41             try {
42                 if ($runner->iterate()) {
43                     if ($runner->hasWork()) {
44                         // More to do? Shove us back on the queue...
45                         $runner->startBackgroundImport();
46                     }
47                 }
48             } catch (Exception $e) {
49                 try {
50                     $runner->recordError($e->getMessage());
51                 } catch (Exception $f) {
52                     common_log(LOG_ERR, "Error while recording error in Yammer background import: " . $e->getMessage() . " " . $f->getMessage());
53                 }
54             }
55         } else {
56             // We're done!
57             common_log(LOG_INFO, "Yammer import has no work to do at this time; discarding.");
58         }
59         return true;
60     }
61 }