| 
									
										
										
										
											2008-08-27 16:54:07 -04:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * Laconica - a distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2009-06-20 16:12:55 -07:00
										 |  |  |  * Copyright (C) 2008, 2009, Control Yourself, Inc. | 
					
						
							| 
									
										
										
										
											2008-08-27 16:54:07 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * 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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-04 14:40:31 -04:00
										 |  |  | if (!defined('LACONICA')) { exit(1); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once(INSTALLDIR.'/lib/daemon.php'); | 
					
						
							| 
									
										
										
										
											2008-10-05 15:15:05 -04:00
										 |  |  | require_once(INSTALLDIR.'/classes/Queue_item.php'); | 
					
						
							|  |  |  | require_once(INSTALLDIR.'/classes/Notice.php'); | 
					
						
							| 
									
										
										
										
											2008-09-04 14:40:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  | define('CLAIM_TIMEOUT', 1200); | 
					
						
							|  |  |  | define('QUEUE_HANDLER_MISS_IDLE', 10); | 
					
						
							| 
									
										
										
										
											2009-07-04 00:31:28 -04:00
										 |  |  | define('QUEUE_HANDLER_HIT_IDLE', 0); | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:49:23 -05:00
										 |  |  | class QueueHandler extends Daemon | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     var $_id = 'generic'; | 
					
						
							| 
									
										
										
										
											2008-08-27 16:54:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-28 16:12:23 -04:00
										 |  |  |     function __construct($id=null, $daemonize=true) | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-06-28 16:12:23 -04:00
										 |  |  |         parent::__construct($daemonize); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         if ($id) { | 
					
						
							|  |  |  |             $this->set_id($id); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  |     function timeout() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-07-04 00:31:28 -04:00
										 |  |  |         return 60; | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function class_name() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return ucfirst($this->transport()) . 'Handler'; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-09-04 14:40:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function name() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return strtolower($this->class_name().'.'.$this->get_id()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function get_id() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return $this->_id; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-08-27 16:54:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function set_id($id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $this->_id = $id; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function transport() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:21:29 -05:00
										 |  |  |         return null; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function start() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function finish() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-08-27 16:54:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function handle_notice($notice) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  |     function run() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!$this->start()) { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-06-24 19:17:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  |         $this->log(LOG_INFO, 'checking for queued notices'); | 
					
						
							| 
									
										
										
										
											2009-06-24 19:17:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  |         $queue   = $this->transport(); | 
					
						
							|  |  |  |         $timeout = $this->timeout(); | 
					
						
							| 
									
										
										
										
											2009-06-24 19:17:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  |         $qm = QueueManager::get(); | 
					
						
							| 
									
										
										
										
											2009-06-24 19:17:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-04 00:31:28 -04:00
										 |  |  |         $qm->service($queue, $this); | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         if (!$this->finish()) { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-08-27 16:54:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function idle($timeout=0) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-07-01 12:11:02 -04:00
										 |  |  |         if ($timeout > 0) { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             sleep($timeout); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function log($level, $msg) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         common_log($level, $this->class_name() . ' ('. $this->get_id() .'): '.$msg); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-08-27 16:54:07 -04:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-04-03 12:45:54 -04:00
										 |  |  | 
 |