mirror of
				https://bitbucket.org/jsuto/piler.git
				synced 2025-10-26 07:32:28 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			334 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			334 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Zend Framework
 | |
|  *
 | |
|  * LICENSE
 | |
|  *
 | |
|  * This source file is subject to the new BSD license that is bundled
 | |
|  * with this package in the file LICENSE.txt.
 | |
|  * It is also available through the world-wide-web at this URL:
 | |
|  * http://framework.zend.com/license/new-bsd
 | |
|  * If you did not receive a copy of the license and are unable to
 | |
|  * obtain it through the world-wide-web, please send an email
 | |
|  * to license@zend.com so we can send you a copy immediately.
 | |
|  *
 | |
|  * @category   Zend
 | |
|  * @package    Zend_Mime
 | |
|  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license    http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  * @version    $Id$
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Zend_Mime
 | |
|  */
 | |
| require_once 'Zend/Mime.php';
 | |
| 
 | |
| /**
 | |
|  * Class representing a MIME part.
 | |
|  *
 | |
|  * @category   Zend
 | |
|  * @package    Zend_Mime
 | |
|  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license    http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  */
 | |
| class Zend_Mime_Part
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * Type
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $type = Zend_Mime::TYPE_OCTETSTREAM;
 | |
| 
 | |
|     /**
 | |
|      * Encoding
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $encoding = Zend_Mime::ENCODING_8BIT;
 | |
| 
 | |
|     /**
 | |
|      * ID
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $id;
 | |
| 
 | |
|     /**
 | |
|      * Disposition
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $disposition;
 | |
| 
 | |
|     /**
 | |
|      * Filename
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $filename;
 | |
| 
 | |
|     /**
 | |
|      * Description
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $description;
 | |
| 
 | |
|     /**
 | |
|      * Character set
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $charset;
 | |
| 
 | |
|     /**
 | |
|      * Boundary
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $boundary;
 | |
| 
 | |
|     /**
 | |
|      * Location
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $location;
 | |
| 
 | |
|     /**
 | |
|      * Language
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     public $language;
 | |
| 
 | |
|     /**
 | |
|      * Content
 | |
|      *
 | |
|      * @var mixed
 | |
|      */
 | |
|     protected $_content;
 | |
| 
 | |
|     /**
 | |
|      * @var bool
 | |
|      */
 | |
|     protected $_isStream = false;
 | |
| 
 | |
|     /**
 | |
|      * create a new Mime Part.
 | |
|      * The (unencoded) content of the Part as passed
 | |
|      * as a string or stream
 | |
|      *
 | |
|      * @param mixed $content String or Stream containing the content
 | |
|      */
 | |
|     public function __construct($content)
 | |
|     {
 | |
|         $this->_content = $content;
 | |
|         if (is_resource($content)) {
 | |
|             $this->_isStream = true;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @todo setters/getters
 | |
|      * @todo error checking for setting $type
 | |
|      * @todo error checking for setting $encoding
 | |
|      */
 | |
| 
 | |
|     /**
 | |
|      * check if this part can be read as a stream.
 | |
|      * if true, getEncodedStream can be called, otherwise
 | |
|      * only getContent can be used to fetch the encoded
 | |
|      * content of the part
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function isStream()
 | |
|     {
 | |
|         return $this->_isStream;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * if this was created with a stream, return a filtered stream for
 | |
|      * reading the content. very useful for large file attachments.
 | |
|      *
 | |
|      * @return mixed Stream
 | |
|      * @throws Zend_Mime_Exception if not a stream or unable to append filter
 | |
|      */
 | |
|     public function getEncodedStream()
 | |
|     {
 | |
|         if (!$this->_isStream) {
 | |
|             require_once 'Zend/Mime/Exception.php';
 | |
|             throw new Zend_Mime_Exception(
 | |
|                 'Attempt to get a stream from a string part'
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         //stream_filter_remove(); // ??? is that right?
 | |
|         switch ($this->encoding) {
 | |
|             case Zend_Mime::ENCODING_QUOTEDPRINTABLE:
 | |
|                 $filter = stream_filter_append(
 | |
|                     $this->_content,
 | |
|                     'convert.quoted-printable-encode',
 | |
|                     STREAM_FILTER_READ,
 | |
|                     array(
 | |
|                         'line-length'      => 76,
 | |
|                         'line-break-chars' => Zend_Mime::LINEEND
 | |
|                     )
 | |
|                 );
 | |
|                 if (!is_resource($filter)) {
 | |
|                     require_once 'Zend/Mime/Exception.php';
 | |
|                     throw new Zend_Mime_Exception(
 | |
|                         'Failed to append quoted-printable filter'
 | |
|                     );
 | |
|                 }
 | |
|                 break;
 | |
| 
 | |
|             case Zend_Mime::ENCODING_BASE64:
 | |
|                 $filter = stream_filter_append(
 | |
|                     $this->_content,
 | |
|                     'convert.base64-encode',
 | |
|                     STREAM_FILTER_READ,
 | |
|                     array(
 | |
|                         'line-length'      => 76,
 | |
|                         'line-break-chars' => Zend_Mime::LINEEND
 | |
|                     )
 | |
|                 );
 | |
|                 if (!is_resource($filter)) {
 | |
|                     require_once 'Zend/Mime/Exception.php';
 | |
|                     throw new Zend_Mime_Exception(
 | |
|                         'Failed to append base64 filter'
 | |
|                     );
 | |
|                 }
 | |
|                 break;
 | |
| 
 | |
|             default:
 | |
|         }
 | |
| 
 | |
|         return $this->_content;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the Content of the current Mime Part in the given encoding.
 | |
|      *
 | |
|      * @param  string $EOL Line end; defaults to {@link Zend_Mime::LINEEND}
 | |
|      * @throws Zend_Mime_Exception
 | |
|      * @return string
 | |
|      */
 | |
|     public function getContent($EOL = Zend_Mime::LINEEND)
 | |
|     {
 | |
|         if ($this->_isStream) {
 | |
|             return stream_get_contents($this->getEncodedStream());
 | |
|         } else {
 | |
|             return Zend_Mime::encode($this->_content, $this->encoding, $EOL);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the RAW unencoded content from this part
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function getRawContent()
 | |
|     {
 | |
|         if ($this->_isStream) {
 | |
|             return stream_get_contents($this->_content);
 | |
|         } else {
 | |
|             return $this->_content;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Create and return the array of headers for this MIME part
 | |
|      *
 | |
|      * @param  string $EOL Line end; defaults to {@link Zend_Mime::LINEEND}
 | |
|      * @return array
 | |
|      */
 | |
|     public function getHeadersArray($EOL = Zend_Mime::LINEEND)
 | |
|     {
 | |
|         $headers = array();
 | |
| 
 | |
|         $contentType = $this->type;
 | |
|         if ($this->charset) {
 | |
|             $contentType .= '; charset=' . $this->charset;
 | |
|         }
 | |
| 
 | |
|         if ($this->boundary) {
 | |
|             $contentType .= ';' . $EOL
 | |
|                             . " boundary=\"" . $this->boundary . '"';
 | |
|         }
 | |
| 
 | |
|         $headers[] = array(
 | |
|             'Content-Type',
 | |
|             $contentType
 | |
|         );
 | |
| 
 | |
|         if ($this->encoding) {
 | |
|             $headers[] = array(
 | |
|                 'Content-Transfer-Encoding',
 | |
|                 $this->encoding
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         if ($this->id) {
 | |
|             $headers[] = array(
 | |
|                 'Content-ID',
 | |
|                 '<' . $this->id . '>'
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         if ($this->disposition) {
 | |
|             $disposition = $this->disposition;
 | |
|             if ($this->filename) {
 | |
|                 $disposition .= '; filename="' . $this->filename . '"';
 | |
|             }
 | |
|             $headers[] = array(
 | |
|                 'Content-Disposition',
 | |
|                 $disposition
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         if ($this->description) {
 | |
|             $headers[] = array(
 | |
|                 'Content-Description',
 | |
|                 $this->description
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         if ($this->location) {
 | |
|             $headers[] = array(
 | |
|                 'Content-Location',
 | |
|                 $this->location
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         if ($this->language) {
 | |
|             $headers[] = array(
 | |
|                 'Content-Language',
 | |
|                 $this->language
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         return $headers;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the headers for this part as a string
 | |
|      *
 | |
|      * @param  string $EOL Line end; defaults to {@link Zend_Mime::LINEEND}
 | |
|      * @return string
 | |
|      */
 | |
|     public function getHeaders($EOL = Zend_Mime::LINEEND)
 | |
|     {
 | |
|         $res = '';
 | |
|         foreach ($this->getHeadersArray($EOL) as $header) {
 | |
|             $res .= $header[0] . ': ' . $header[1] . $EOL;
 | |
|         }
 | |
| 
 | |
|         return $res;
 | |
|     }
 | |
| }
 |