| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * StatusNet - the distributed open-source microblogging tool | 
					
						
							|  |  |  |  * Copyright (C) 2009, StatusNet, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Send and receive notices using the MSN network | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // We bundle the phpmsnclass library...
 | 
					
						
							|  |  |  | set_include_path(get_include_path() . PATH_SEPARATOR . dirname(__FILE__) . '/extlib/phpmsnclass'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Plugin for MSN | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @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 MsnPlugin extends ImPlugin { | 
					
						
							|  |  |  |     public $user = null; | 
					
						
							|  |  |  |     public $password = null; | 
					
						
							|  |  |  |     public $nickname = null; | 
					
						
							| 
									
										
										
										
											2010-06-22 20:26:23 -07:00
										 |  |  |     public $transport = 'msn'; | 
					
						
							| 
									
										
										
										
											2010-07-18 12:58:06 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get the internationalized/translated display name of this IM service | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string Name of service | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-06-16 00:04:59 +01:00
										 |  |  |     public function getDisplayName() { | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |         return _m('MSN'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Normalize a screenname for comparison | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $screenname screenname to normalize | 
					
						
							|  |  |  |      * @return string an equivalent screenname in normalized form | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-06-16 00:04:59 +01:00
										 |  |  |     public function normalize($screenname) { | 
					
						
							| 
									
										
										
										
											2010-07-18 12:58:06 -07:00
										 |  |  |         $screenname = str_replace(" ","", $screenname); | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |         return strtolower($screenname); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Get the screenname of the daemon that sends and receives messages | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string Screenname | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-06-16 00:04:59 +01:00
										 |  |  |     public function daemon_screenname() { | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |         return $this->user; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Validate (ensure the validity of) a screenname | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $screenname screenname to validate | 
					
						
							|  |  |  |      * @return boolean | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-06-16 00:04:59 +01:00
										 |  |  |     public function validate($screenname) { | 
					
						
							| 
									
										
										
										
											2010-06-20 15:53:36 +01:00
										 |  |  |         return Validate::email($screenname, common_config('email', 'check_domain')); | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 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. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function onAutoload($cls) { | 
					
						
							|  |  |  |         $dir = dirname(__FILE__); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         switch ($cls) { | 
					
						
							| 
									
										
										
										
											2010-06-15 20:51:04 +01:00
										 |  |  |             case 'MSN': | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |                 require_once(INSTALLDIR.'/plugins/Msn/extlib/phpmsnclass/msn.class.php'); | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             case 'MsnManager': | 
					
						
							| 
									
										
										
										
											2010-07-30 17:12:35 -07:00
										 |  |  |             case 'Msn_waiting_message': | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |                 include_once $dir . '/'.strtolower($cls).'.php'; | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |                 return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-16 14:15:08 +01:00
										 |  |  |     /* | 
					
						
							|  |  |  |      * Start manager on daemon start | 
					
						
							| 
									
										
										
										
											2010-07-18 12:58:06 -07:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-06-16 14:15:08 +01:00
										 |  |  |      * @return boolean | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |     public function onStartImDaemonIoManagers(&$classes) { | 
					
						
							|  |  |  |         parent::onStartImDaemonIoManagers(&$classes); | 
					
						
							|  |  |  |         $classes[] = new MsnManager($this); // handles sending/receiving
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-30 17:12:35 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Ensure the database table is present | 
					
						
							|  |  |  |     * | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function onCheckSchema() { | 
					
						
							|  |  |  |         $schema = Schema::get(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // For storing messages while sessions become ready
 | 
					
						
							|  |  |  |         $schema->ensureTable('msn_waiting_message', | 
					
						
							|  |  |  |                              array(new ColumnDef('id', 'integer', null, | 
					
						
							|  |  |  |                                                  false, 'PRI', null, null, true), | 
					
						
							| 
									
										
										
										
											2010-07-31 10:47:58 -07:00
										 |  |  |                                    new ColumnDef('screenname', 'varchar', 255, false), | 
					
						
							| 
									
										
										
										
											2010-07-30 17:12:35 -07:00
										 |  |  |                                    new ColumnDef('message', 'text', null, false), | 
					
						
							|  |  |  |                                    new ColumnDef('created', 'datetime', null, false), | 
					
						
							|  |  |  |                                    new ColumnDef('claimed', 'datetime'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Get a microid URI for the given screenname | 
					
						
							|  |  |  |     * | 
					
						
							|  |  |  |     * @param string $screenname | 
					
						
							|  |  |  |     * @return string microid URI | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function microiduri($screenname) { | 
					
						
							|  |  |  |         return 'msnim:' . $screenname; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Send a message to a given screenname | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $screenname Screenname to send to | 
					
						
							|  |  |  |      * @param string $body Text to send | 
					
						
							|  |  |  |      * @return boolean success value | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function send_message($screenname, $body) { | 
					
						
							| 
									
										
										
										
											2010-07-18 12:58:06 -07:00
										 |  |  |         $this->enqueue_outgoing_raw(array('to' => $screenname, 'message' => $body)); | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Accept a queued input message. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $data Data | 
					
						
							|  |  |  |      * @return true if processing completed, false if message should be reprocessed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function receive_raw_message($data) { | 
					
						
							|  |  |  |         $this->handle_incoming($data['sender'], $data['message']); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |     * Initialize plugin | 
					
						
							|  |  |  |     * | 
					
						
							| 
									
										
										
										
											2010-06-16 00:04:59 +01:00
										 |  |  |     * @return boolean | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |     */ | 
					
						
							|  |  |  |     public function initialize() { | 
					
						
							|  |  |  |         if (!isset($this->user)) { | 
					
						
							|  |  |  |             throw new Exception("Must specify a user"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!isset($this->password)) { | 
					
						
							|  |  |  |             throw new Exception("Must specify a password"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!isset($this->nickname)) { | 
					
						
							|  |  |  |             throw new Exception("Must specify a nickname"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-16 00:04:59 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get plugin information | 
					
						
							| 
									
										
										
										
											2010-07-18 12:58:06 -07:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-06-16 00:04:59 +01:00
										 |  |  |      * @param array $versions array to insert information into | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function onPluginVersion(&$versions) { | 
					
						
							| 
									
										
										
										
											2010-06-15 20:51:04 +01:00
										 |  |  |         $versions[] = array( | 
					
						
							|  |  |  |             'name' => 'MSN', | 
					
						
							|  |  |  |             'version' => STATUSNET_VERSION, | 
					
						
							|  |  |  |             'author' => 'Luke Fitzgerald', | 
					
						
							|  |  |  |             'homepage' => 'http://status.net/wiki/Plugin:MSN', | 
					
						
							|  |  |  |             'rawdescription' => | 
					
						
							|  |  |  |             _m('The MSN plugin allows users to send and receive notices over the MSN network.') | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2010-06-14 19:53:43 +01:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |