You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							191 lines
						
					
					
						
							5.3 KiB
						
					
					
				
			
		
		
	
	
							191 lines
						
					
					
						
							5.3 KiB
						
					
					
				| <?php
 | |
| 
 | |
| /**
 | |
|  * @file
 | |
|  * TeamSpeak 3 PHP Framework
 | |
|  *
 | |
|  * $Id: FileTransfer.php 06/06/2016 22:27:13 scp@Svens-iMac $
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU 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 General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program. If not, see <http://www.gnu.org/licenses/>.
 | |
|  *
 | |
|  * @package   TeamSpeak3
 | |
|  * @version   1.1.24
 | |
|  * @author    Sven 'ScP' Paulsen
 | |
|  * @copyright Copyright (c) 2010 by Planet TeamSpeak. All rights reserved.
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @class TeamSpeak3_Adapter_FileTransfer
 | |
|  * @brief Provides low-level methods for file transfer communication with a TeamSpeak 3 Server.
 | |
|  */
 | |
| class TeamSpeak3_Adapter_FileTransfer extends TeamSpeak3_Adapter_Abstract
 | |
| {
 | |
|   /**
 | |
|    * Connects the TeamSpeak3_Transport_Abstract object and performs initial actions on the remote
 | |
|    * server.
 | |
|    *
 | |
|    * @throws TeamSpeak3_Adapter_Exception
 | |
|    * @return void
 | |
|    */
 | |
|   public function syn()
 | |
|   {
 | |
|     $this->initTransport($this->options);
 | |
|     $this->transport->setAdapter($this);
 | |
| 
 | |
|     TeamSpeak3_Helper_Profiler::init(spl_object_hash($this));
 | |
| 
 | |
|     TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferConnected", $this);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * The TeamSpeak3_Adapter_FileTransfer destructor.
 | |
|    *
 | |
|    * @return void
 | |
|    */
 | |
|   public function __destruct()
 | |
|   {
 | |
|     if($this->getTransport() instanceof TeamSpeak3_Transport_Abstract && $this->getTransport()->isConnected())
 | |
|     {
 | |
|       $this->getTransport()->disconnect();
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Sends a valid file transfer key to the server to initialize the file transfer.
 | |
|    *
 | |
|    * @param  string $ftkey
 | |
|    * @throws TeamSpeak3_Adapter_FileTransfer_Exception
 | |
|    * @return void
 | |
|    */
 | |
|   protected function init($ftkey)
 | |
|   {
 | |
|     if(strlen($ftkey) != 32)
 | |
|     {
 | |
|       throw new TeamSpeak3_Adapter_FileTransfer_Exception("invalid file transfer key format");
 | |
|     }
 | |
| 
 | |
|     $this->getProfiler()->start();
 | |
|     $this->getTransport()->send($ftkey);
 | |
| 
 | |
|     TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferHandshake", $this);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Sends the content of a file to the server.
 | |
|    *
 | |
|    * @param  string  $ftkey
 | |
|    * @param  integer $seek
 | |
|    * @param  string  $data
 | |
|    * @throws TeamSpeak3_Adapter_FileTransfer_Exception
 | |
|    * @return void
 | |
|    */
 | |
|   public function upload($ftkey, $seek, $data)
 | |
|   {
 | |
|     $this->init($ftkey);
 | |
| 
 | |
|     $size = strlen($data);
 | |
|     $seek = intval($seek);
 | |
|     $pack = 4096;
 | |
| 
 | |
|     TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferUploadStarted", $ftkey, $seek, $size);
 | |
| 
 | |
|     for(;$seek < $size;)
 | |
|     {
 | |
|       $rest = $size-$seek;
 | |
|       $pack = $rest < $pack ? $rest : $pack;
 | |
|       $buff = substr($data, $seek, $pack);
 | |
|       $seek = $seek+$pack;
 | |
| 
 | |
|       $this->getTransport()->send($buff);
 | |
| 
 | |
|       TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferUploadProgress", $ftkey, $seek, $size);
 | |
|     }
 | |
| 
 | |
|     $this->getProfiler()->stop();
 | |
| 
 | |
|     TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferUploadFinished", $ftkey, $seek, $size);
 | |
| 
 | |
|     if($seek < $size)
 | |
|     {
 | |
|       throw new TeamSpeak3_Adapter_FileTransfer_Exception("incomplete file upload (" . $seek . " of " . $size . " bytes)");
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Returns the content of a downloaded file as a TeamSpeak3_Helper_String object.
 | |
|    *
 | |
|    * @param  string  $ftkey
 | |
|    * @param  integer $size
 | |
|    * @param  boolean $passthru
 | |
|    * @throws TeamSpeak3_Adapter_FileTransfer_Exception
 | |
|    * @return TeamSpeak3_Helper_String
 | |
|    */
 | |
|   public function download($ftkey, $size, $passthru = FALSE)
 | |
|   {
 | |
|     $this->init($ftkey);
 | |
| 
 | |
|     if($passthru)
 | |
|     {
 | |
|       return $this->passthru($size);
 | |
|     }
 | |
| 
 | |
|     $buff = new TeamSpeak3_Helper_String("");
 | |
|     $size = intval($size);
 | |
|     $pack = 4096;
 | |
| 
 | |
|     TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferDownloadStarted", $ftkey, count($buff), $size);
 | |
| 
 | |
|     for($seek = 0;$seek < $size;)
 | |
|     {
 | |
|       $rest = $size-$seek;
 | |
|       $pack = $rest < $pack ? $rest : $pack;
 | |
|       $data = $this->getTransport()->read($rest < $pack ? $rest : $pack);
 | |
|       $seek = $seek+$pack;
 | |
| 
 | |
|       $buff->append($data);
 | |
| 
 | |
|       TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferDownloadProgress", $ftkey, count($buff), $size);
 | |
|     }
 | |
| 
 | |
|     $this->getProfiler()->stop();
 | |
| 
 | |
|     TeamSpeak3_Helper_Signal::getInstance()->emit("filetransferDownloadFinished", $ftkey, count($buff), $size);
 | |
| 
 | |
|     if(strlen($buff) != $size)
 | |
|     {
 | |
|       throw new TeamSpeak3_Adapter_FileTransfer_Exception("incomplete file download (" . count($buff) . " of " . $size . " bytes)");
 | |
|     }
 | |
| 
 | |
|     return $buff;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Outputs all remaining data on a TeamSpeak 3 file transfer stream using PHP's fpassthru()
 | |
|    * function.
 | |
|    *
 | |
|    * @param  integer $size
 | |
|    * @throws TeamSpeak3_Adapter_FileTransfer_Exception
 | |
|    * @return void
 | |
|    */
 | |
|   protected function passthru($size)
 | |
|   {
 | |
|     $buff_size = fpassthru($this->getTransport()->getStream());
 | |
| 
 | |
|     if($buff_size != $size)
 | |
|     {
 | |
|       throw new TeamSpeak3_Adapter_FileTransfer_Exception("incomplete file download (" . intval($buff_size) . " of " . $size . " bytes)");
 | |
|     }
 | |
|   }
 | |
| }
 |