tweetctlqueuehandler.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  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. if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); }
  20. require_once __DIR__ . '/twitter.php';
  21. /**
  22. * Queue handler to deal with incoming Twitter status updates, as retrieved by
  23. * TwitterDaemon (twitterdaemon.php).
  24. *
  25. * The queue handler passes the status through TwitterImporter for import into the
  26. * local database (if necessary), then adds the imported notice to the local inbox
  27. * of the attached Twitter user.
  28. *
  29. * Warning: the way we do inbox distribution manually means that realtime, XMPP, etc
  30. * don't work on Twitter-borne messages. When TwitterImporter is changed to handle
  31. * that correctly, we'll only need to do this once...?
  32. */
  33. class TweetCtlQueueHandler extends QueueHandler
  34. {
  35. function transport()
  36. {
  37. return 'tweetctl';
  38. }
  39. function handle($data) : bool
  40. {
  41. // A user has activated or deactivated their Twitter bridge
  42. // import status.
  43. $action = $data['action'];
  44. $userId = $data['for_user'];
  45. $tm = TwitterManager::get();
  46. if ($action == 'start') {
  47. $tm->startTwitterUser($userId);
  48. } else if ($action == 'stop') {
  49. $tm->stopTwitterUser($userId);
  50. }
  51. return true;
  52. }
  53. }