| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * StatusNet - the distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |  * Copyright (C) 2010, StatusNet, Inc. | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |  * Send and receive notices using an IRC network | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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/>. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category  IM | 
					
						
							|  |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Luke Fitzgerald <lw.fitzgerald@googlemail.com> | 
					
						
							|  |  |  |  * @copyright 2010 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!defined('STATUSNET')) { | 
					
						
							|  |  |  |     // This check helps protect against security problems;
 | 
					
						
							|  |  |  |     // your code file can't be executed directly from the web.
 | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-07-20 11:16:59 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  | // We bundle the Phergie library...
 | 
					
						
							|  |  |  | set_include_path(get_include_path() . PATH_SEPARATOR . dirname(__FILE__) . '/extlib/phergie'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Plugin for IRC | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category  Plugin | 
					
						
							|  |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Luke Fitzgerald <lw.fitzgerald@googlemail.com> | 
					
						
							|  |  |  |  * @copyright 2010 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class IrcPlugin extends ImPlugin { | 
					
						
							| 
									
										
										
										
											2010-07-20 11:16:59 -07:00
										 |  |  |     public $host =  null; | 
					
						
							|  |  |  |     public $port = null; | 
					
						
							|  |  |  |     public $username = null; | 
					
						
							|  |  |  |     public $realname = null; | 
					
						
							|  |  |  |     public $nick = null; | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |     public $password = null; | 
					
						
							| 
									
										
										
										
											2010-07-26 11:13:00 -07:00
										 |  |  |     public $nickservidentifyregexp = null; | 
					
						
							| 
									
										
										
										
											2010-07-20 11:16:59 -07:00
										 |  |  |     public $nickservpassword = null; | 
					
						
							|  |  |  |     public $channels = null; | 
					
						
							|  |  |  |     public $transporttype = null; | 
					
						
							|  |  |  |     public $encoding = null; | 
					
						
							| 
									
										
										
										
											2010-08-11 10:49:09 -07:00
										 |  |  |     public $pinginterval = null; | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  |     public $regcheck = null; | 
					
						
							| 
									
										
										
										
											2010-07-26 11:13:00 -07:00
										 |  |  |     public $unregregexp = null; | 
					
						
							|  |  |  |     public $regregexp = null; | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |     public $transport = 'irc'; | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |     protected $whiteList; | 
					
						
							|  |  |  |     protected $fake_irc; | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get the internationalized/translated display name of this IM service | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string Name of service | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getDisplayName() { | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         return _m('IRC'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Normalize a screenname for comparison | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @param string $screenname Screenname to normalize | 
					
						
							|  |  |  |      * @return string An equivalent screenname in normalized form | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function normalize($screenname) { | 
					
						
							|  |  |  |         $screenname = str_replace(" ","", $screenname); | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         return strtolower($screenname); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get the screenname of the daemon that sends and receives messages | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string Screenname | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-08-31 00:04:16 -04:00
										 |  |  |     public function daemonScreenname() { | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |         return $this->nick; | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Validate (ensure the validity of) a screenname | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @param string $screenname Screenname to validate | 
					
						
							|  |  |  |      * @return boolean true if screenname is valid | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function validate($screenname) { | 
					
						
							|  |  |  |         if (preg_match('/\A[a-z0-9\-_]{1,1000}\z/i', $screenname)) { | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |             return true; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Load related modules when needed | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $cls Name of the class to be loaded | 
					
						
							|  |  |  |      * @return boolean hook value; true means continue processing, false means stop. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     public function onAutoload($cls) { | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         $dir = dirname(__FILE__); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         switch ($cls) { | 
					
						
							|  |  |  |             case 'IrcManager': | 
					
						
							|  |  |  |                 include_once $dir . '/'.strtolower($cls).'.php'; | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             case 'Fake_Irc': | 
					
						
							| 
									
										
										
										
											2010-08-10 17:27:02 -07:00
										 |  |  |             case 'Irc_waiting_message': | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |             case 'ChannelResponseChannel': | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |                 include_once $dir . '/'. $cls .'.php'; | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             default: | 
					
						
							| 
									
										
										
										
											2010-07-20 11:16:59 -07:00
										 |  |  |                 if (substr($cls, 0, 7) == 'Phergie') { | 
					
						
							|  |  |  |                     include_once str_replace('_', DIRECTORY_SEPARATOR, $cls) . '.php'; | 
					
						
							|  |  |  |                     return false; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |                 return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /* | 
					
						
							|  |  |  |      * Start manager on daemon start | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @param array &$versions Array to insert manager into | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |      * @return boolean | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function onStartImDaemonIoManagers(&$classes) { | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         parent::onStartImDaemonIoManagers(&$classes); | 
					
						
							|  |  |  |         $classes[] = new IrcManager($this); // handles sending/receiving
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-10 17:27:02 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Ensure the database table is present | 
					
						
							|  |  |  |     * | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function onCheckSchema() { | 
					
						
							|  |  |  |         $schema = Schema::get(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // For storing messages while sessions become ready
 | 
					
						
							|  |  |  |         $schema->ensureTable('irc_waiting_message', | 
					
						
							|  |  |  |                              array(new ColumnDef('id', 'integer', null, | 
					
						
							|  |  |  |                                                  false, 'PRI', null, null, true), | 
					
						
							|  |  |  |                                    new ColumnDef('data', 'blob', null, false), | 
					
						
							|  |  |  |                                    new ColumnDef('prioritise', 'tinyint', 1, false), | 
					
						
							| 
									
										
										
										
											2010-08-10 19:23:45 -07:00
										 |  |  |                                    new ColumnDef('attempts', 'integer', null, false), | 
					
						
							| 
									
										
										
										
											2010-08-10 17:27:02 -07:00
										 |  |  |                                    new ColumnDef('created', 'datetime', null, false), | 
					
						
							|  |  |  |                                    new ColumnDef('claimed', 'datetime'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Get a microid URI for the given screenname | 
					
						
							|  |  |  |     * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |     * @param string $screenname Screenname | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     * @return string microid URI | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function microiduri($screenname) { | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         return 'irc:' . $screenname; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Send a message to a given screenname | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $screenname Screenname to send to | 
					
						
							|  |  |  |      * @param string $body Text to send | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @return boolean true on success | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-08-31 00:01:55 -04:00
										 |  |  |     public function sendMessage($screenname, $body) { | 
					
						
							| 
									
										
										
										
											2010-08-04 09:10:57 -07:00
										 |  |  |         $lines = explode("\n", $body); | 
					
						
							|  |  |  |         foreach ($lines as $line) { | 
					
						
							|  |  |  |             $this->fake_irc->doPrivmsg($screenname, $line); | 
					
						
							| 
									
										
										
										
											2010-08-31 00:05:03 -04:00
										 |  |  |             $this->enqueueOutgoingRaw(array('type' => 'message', 'prioritise' => 0, 'data' => $this->fake_irc->would_be_sent)); | 
					
						
							| 
									
										
										
										
											2010-08-04 09:10:57 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Accept a queued input message. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @return boolean true if processing completed, false if message should be reprocessed | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-08-31 00:03:37 -04:00
										 |  |  |     public function receiveRawMessage($data) { | 
					
						
							| 
									
										
										
										
											2010-08-05 10:48:15 -07:00
										 |  |  |         if (strpos($data['source'], '#') === 0) { | 
					
						
							|  |  |  |             $message = $data['message']; | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |             $parts = explode(' ', $message, 2); | 
					
						
							|  |  |  |             $command = $parts[0]; | 
					
						
							|  |  |  |             if (in_array($command, $this->whiteList)) { | 
					
						
							|  |  |  |                 $this->handle_channel_incoming($data['sender'], $data['source'], $message); | 
					
						
							|  |  |  |             } else { | 
					
						
							| 
									
										
										
										
											2010-08-31 00:11:57 -04:00
										 |  |  |                 $this->handleIncoming($data['sender'], $message); | 
					
						
							| 
									
										
										
										
											2010-08-05 10:48:15 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2010-08-31 00:11:57 -04:00
										 |  |  |             $this->handleIncoming($data['sender'], $data['message']); | 
					
						
							| 
									
										
										
										
											2010-08-05 10:48:15 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Helper for handling incoming messages from a channel requiring response | 
					
						
							|  |  |  |      * to the channel instead of via PM | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $nick Screenname the message was sent from | 
					
						
							|  |  |  |      * @param string $channel Channel the message originated from | 
					
						
							|  |  |  |      * @param string $message Message text | 
					
						
							|  |  |  |      * @param boolean true on success | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |     protected function handle_channel_incoming($nick, $channel, $notice_text) { | 
					
						
							| 
									
										
										
										
											2010-08-31 00:14:47 -04:00
										 |  |  |         $user = $this->getUser($nick); | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |         // For common_current_user to work
 | 
					
						
							|  |  |  |         global $_cur; | 
					
						
							|  |  |  |         $_cur = $user; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!$user) { | 
					
						
							| 
									
										
										
										
											2010-08-31 00:07:52 -04:00
										 |  |  |             $this->sendFromSite($nick, 'Unknown user; go to ' . | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |                              common_local_url('imsettings') . | 
					
						
							|  |  |  |                              ' to add your address to your account'); | 
					
						
							|  |  |  |             common_log(LOG_WARNING, 'Message from unknown user ' . $nick); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($this->handle_channel_command($user, $channel, $notice_text)) { | 
					
						
							|  |  |  |             common_log(LOG_INFO, "Command message by $nick handled."); | 
					
						
							|  |  |  |             return; | 
					
						
							| 
									
										
										
										
											2010-08-31 00:20:05 -04:00
										 |  |  |         } else if ($this->isAutoreply($notice_text)) { | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |             common_log(LOG_INFO, 'Ignoring auto reply from ' . $nick); | 
					
						
							|  |  |  |             return; | 
					
						
							| 
									
										
										
										
											2010-08-31 00:21:51 -04:00
										 |  |  |         } else if ($this->isOtr($notice_text)) { | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |             common_log(LOG_INFO, 'Ignoring OTR from ' . $nick); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             common_log(LOG_INFO, 'Posting a notice from ' . $user->nickname); | 
					
						
							| 
									
										
										
										
											2010-08-31 00:13:17 -04:00
										 |  |  |             $this->addNotice($nick, $user, $notice_text); | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $user->free(); | 
					
						
							|  |  |  |         unset($user); | 
					
						
							|  |  |  |         unset($_cur); | 
					
						
							|  |  |  |         unset($message); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Attempt to handle a message from a channel as a command | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @param User $user User the message is from | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |      * @param string $channel Channel the message originated from | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @param string $body Message text | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  |      * @return boolean true if the message was a command and was executed, false if it was not a command | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function handle_channel_command($user, $channel, $body) { | 
					
						
							|  |  |  |         $inter = new CommandInterpreter(); | 
					
						
							|  |  |  |         $cmd = $inter->handle_command($user, $body); | 
					
						
							|  |  |  |         if ($cmd) { | 
					
						
							|  |  |  |             $chan = new ChannelResponseChannel($this, $channel); | 
					
						
							|  |  |  |             $cmd->execute($chan); | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Send a confirmation code to a user | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $screenname screenname sending to | 
					
						
							|  |  |  |      * @param string $code the confirmation code | 
					
						
							|  |  |  |      * @param User $user user sending to | 
					
						
							|  |  |  |      * @return boolean success value | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-08-31 00:08:28 -04:00
										 |  |  |     public function sendConfirmationCode($screenname, $code, $user, $checked = false) { | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  |         $body = sprintf(_('User "%s" on %s has said that your %s screenname belongs to them. ' . | 
					
						
							|  |  |  |           'If that\'s true, you can confirm by clicking on this URL: ' . | 
					
						
							|  |  |  |           '%s' . | 
					
						
							|  |  |  |           ' . (If you cannot click it, copy-and-paste it into the ' . | 
					
						
							|  |  |  |           'address bar of your browser). If that user isn\'t you, ' . | 
					
						
							|  |  |  |           'or if you didn\'t request this confirmation, just ignore this message.'), | 
					
						
							|  |  |  |           $user->nickname, common_config('site', 'name'), $this->getDisplayName(), common_local_url('confirmaddress', array('code' => $code))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($this->regcheck && !$checked) { | 
					
						
							| 
									
										
										
										
											2010-08-31 00:08:28 -04:00
										 |  |  |             return $this->checked_sendConfirmationCode($screenname, $code, $user); | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2010-08-31 00:01:55 -04:00
										 |  |  |             return $this->sendMessage($screenname, $body); | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 14:13:23 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Only sends the confirmation message if the nick is | 
					
						
							|  |  |  |     * registered | 
					
						
							|  |  |  |     * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |     * @param string $screenname Screenname sending to | 
					
						
							|  |  |  |     * @param string $code The confirmation code | 
					
						
							|  |  |  |     * @param User $user User sending to | 
					
						
							|  |  |  |     * @return boolean true on succes | 
					
						
							| 
									
										
										
										
											2010-07-23 14:13:23 -07:00
										 |  |  |     */ | 
					
						
							| 
									
										
										
										
											2010-08-31 00:08:28 -04:00
										 |  |  |     public function checked_sendConfirmationCode($screenname, $code, $user) { | 
					
						
							| 
									
										
										
										
											2010-07-23 14:13:23 -07:00
										 |  |  |         $this->fake_irc->doPrivmsg('NickServ', 'INFO '.$screenname); | 
					
						
							| 
									
										
										
										
											2010-08-31 00:05:03 -04:00
										 |  |  |         $this->enqueueOutgoingRaw( | 
					
						
							| 
									
										
										
										
											2010-07-23 14:13:23 -07:00
										 |  |  |             array( | 
					
						
							|  |  |  |                 'type' => 'nickcheck', | 
					
						
							| 
									
										
										
										
											2010-08-10 17:27:02 -07:00
										 |  |  |                 'prioritise' => 1, | 
					
						
							| 
									
										
										
										
											2010-07-23 14:13:23 -07:00
										 |  |  |                 'data' => $this->fake_irc->would_be_sent, | 
					
						
							|  |  |  |                 'nickdata' => | 
					
						
							|  |  |  |                     array( | 
					
						
							|  |  |  |                         'screenname' => $screenname, | 
					
						
							|  |  |  |                         'code' => $code, | 
					
						
							|  |  |  |                         'user' => $user | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Initialize plugin | 
					
						
							|  |  |  |     * | 
					
						
							|  |  |  |     * @return boolean | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function initialize() { | 
					
						
							|  |  |  |         if (!isset($this->host)) { | 
					
						
							|  |  |  |             throw new Exception('must specify a host'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!isset($this->username)) { | 
					
						
							|  |  |  |             throw new Exception('must specify a username'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!isset($this->realname)) { | 
					
						
							|  |  |  |             throw new Exception('must specify a "real name"'); | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |         if (!isset($this->nick)) { | 
					
						
							|  |  |  |             throw new Exception('must specify a nickname'); | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  |         if (!isset($this->port)) { | 
					
						
							|  |  |  |             $this->port = 6667; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!isset($this->transporttype)) { | 
					
						
							|  |  |  |             $this->transporttype = 'tcp'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!isset($this->encoding)) { | 
					
						
							|  |  |  |             $this->encoding = 'UTF-8'; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-08-11 10:49:09 -07:00
										 |  |  |         if (!isset($this->pinginterval)) { | 
					
						
							|  |  |  |             $this->pinginterval = 120; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-07-23 13:33:41 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (!isset($this->regcheck)) { | 
					
						
							|  |  |  |             $this->regcheck = true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |         $this->fake_irc = new Fake_Irc; | 
					
						
							| 
									
										
										
										
											2010-08-07 13:25:05 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /* | 
					
						
							|  |  |  |          * Commands allowed to return output to a channel | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         $this->whiteList = array('stats', 'last', 'get'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get plugin information | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-08-07 16:32:17 -07:00
										 |  |  |      * @param array $versions Array to insert information into | 
					
						
							| 
									
										
										
										
											2010-07-18 12:26:11 -07:00
										 |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function onPluginVersion(&$versions) { | 
					
						
							| 
									
										
										
										
											2010-07-04 09:51:44 -07:00
										 |  |  |         $versions[] = array('name' => 'IRC', | 
					
						
							|  |  |  |                             'version' => STATUSNET_VERSION, | 
					
						
							|  |  |  |                             'author' => 'Luke Fitzgerald', | 
					
						
							|  |  |  |                             'homepage' => 'http://status.net/wiki/Plugin:IRC', | 
					
						
							|  |  |  |                             'rawdescription' => | 
					
						
							|  |  |  |                             _m('The IRC plugin allows users to send and receive notices over an IRC network.')); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |