forked from GNUsocial/gnu-social
		
	Moved much of the writing that happens when posting a notice to a new queuehandler, distribqueuehandler. This updates tags, groups, replies and inboxes at queue time (or at Web time, if queues are disabled). To make this work well, I had to break up the monolithic Notice::blowCaches() and make cache blowing happen closer to where data is updated. Squashed commit of the following: commit 5257626c62750ac4ac1db0ce2b71410c5711cfa3 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 14:56:41 2010 -0500 slightly better handling of blowing tag memory cache commit 8a22a3cdf6ec28685da129a0313e7b2a0837c9ef Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 01:42:56 2010 -0500 change 'distribute' to 'distrib' so not too long for dbqueue commit 7a063315b0f7fad27cb6fbd2bdd74e253af83e4f Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 01:39:15 2010 -0500 change handle_notice() to handle() in distributqueuehandler commit 1a39ccd28b9994137d7bfd21bb4f230546938e77 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 16:05:25 2010 -0500 error with queuemanager commit e6b3bb93f305cfd2de71a6340b8aa6fb890049b7 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 01:11:34 2010 -0500 Blow memcache at different point rather than one big function for Notice class commit 94d557cdc016187d1d0647ae1794cd94d6fb8ac8 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 00:48:44 2010 -0500 Blow memcache at different point rather than one big function for Notice class commit 1c781dd08c88a35dafc5c01230b4872fd6b95182 Author: Evan Prodromou <evan@status.net> Date: Wed Jan 20 08:54:18 2010 -0500 move broadcasting and distributing to new queuehandler commit da3e46d26b84e4f028f34a13fd2ee373e4c1b954 Author: Evan Prodromou <evan@status.net> Date: Wed Jan 20 08:53:12 2010 -0500 Move distribution of notices to new distribute queue handler
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /*
 | |
|  * StatusNet - the distributed open-source microblogging tool
 | |
|  * Copyright (C) 2008, 2009, 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/>.
 | |
|  */
 | |
| 
 | |
| if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); }
 | |
| 
 | |
| /**
 | |
|  * Base class for queue handlers.
 | |
|  *
 | |
|  * As extensions of the Daemon class, each queue handler has the ability
 | |
|  * to launch itself in the background, at which point it'll pass control
 | |
|  * to the configured QueueManager class to poll for updates.
 | |
|  *
 | |
|  * Subclasses must override at least the following methods:
 | |
|  * - transport
 | |
|  * - handle_notice
 | |
|  */
 | |
| 
 | |
| class DistribQueueHandler
 | |
| {
 | |
|     /**
 | |
|      * Return transport keyword which identifies items this queue handler
 | |
|      * services; must be defined for all subclasses.
 | |
|      *
 | |
|      * Must be 8 characters or less to fit in the queue_item database.
 | |
|      * ex "email", "jabber", "sms", "irc", ...
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
| 
 | |
|     function transport()
 | |
|     {
 | |
|         return 'distrib';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Here's the meat of your queue handler -- you're handed a Notice
 | |
|      * object, which you may do as you will with.
 | |
|      *
 | |
|      * If this function indicates failure, a warning will be logged
 | |
|      * and the item is placed back in the queue to be re-run.
 | |
|      *
 | |
|      * @param Notice $notice
 | |
|      * @return boolean true on success, false on failure
 | |
|      */
 | |
|     function handle($notice)
 | |
|     {
 | |
|         // XXX: do we need to change this for remote users?
 | |
| 
 | |
|         $notice->saveTags();
 | |
| 
 | |
|         $groups = $notice->saveGroups();
 | |
| 
 | |
|         $recipients = $notice->saveReplies();
 | |
| 
 | |
|         $notice->addToInboxes($groups, $recipients);
 | |
| 
 | |
|         $notice->saveUrls();
 | |
| 
 | |
|         Event::handle('EndNoticeSave', array($notice));
 | |
| 
 | |
|         // Enqueue for other handlers
 | |
| 
 | |
|         common_enqueue_notice($notice);
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| }
 | |
| 
 |