2014-11-13 10:42:49 +01:00
|
|
|
<?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
|
2015-09-01 22:53:57 +02:00
|
|
|
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
|
2014-11-13 10:42:49 +01:00
|
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
|
|
* @version $Id$
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Zend_Mime
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class representing a MIME part.
|
|
|
|
*
|
|
|
|
* @category Zend
|
|
|
|
* @package Zend_Mime
|
2015-09-01 22:53:57 +02:00
|
|
|
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
|
2014-11-13 10:42:49 +01:00
|
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
|
|
*/
|
2015-09-01 22:53:57 +02:00
|
|
|
class Zend_Mime_Part
|
|
|
|
{
|
2014-11-13 10:42:49 +01:00
|
|
|
|
2015-09-01 22:53:57 +02:00
|
|
|
/**
|
|
|
|
* Type
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $type = Zend_Mime::TYPE_OCTETSTREAM;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Encoding
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $encoding = Zend_Mime::ENCODING_8BIT;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ID
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $id;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Disposition
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $disposition;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Filename
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $filename;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Description
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $description;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Character set
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $charset;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Boundary
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $boundary;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Location
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $location;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
public $language;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Content
|
|
|
|
*
|
|
|
|
* @var mixed
|
|
|
|
*/
|
2014-11-13 10:42:49 +01:00
|
|
|
protected $_content;
|
|
|
|
|
2015-09-01 22:53:57 +02:00
|
|
|
/**
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $_isStream = false;
|
2014-11-13 10:42:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* create a new Mime Part.
|
|
|
|
* The (unencoded) content of the Part as passed
|
|
|
|
* as a string or stream
|
|
|
|
*
|
2015-09-01 22:53:57 +02:00
|
|
|
* @param mixed $content String or Stream containing the content
|
2014-11-13 10:42:49 +01:00
|
|
|
*/
|
|
|
|
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()
|
|
|
|
{
|
2015-09-01 22:53:57 +02:00
|
|
|
return $this->_isStream;
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* if this was created with a stream, return a filtered stream for
|
|
|
|
* reading the content. very useful for large file attachments.
|
|
|
|
*
|
2015-09-01 22:53:57 +02:00
|
|
|
* @return mixed Stream
|
2014-11-13 10:42:49 +01:00
|
|
|
* @throws Zend_Mime_Exception if not a stream or unable to append filter
|
|
|
|
*/
|
|
|
|
public function getEncodedStream()
|
|
|
|
{
|
|
|
|
if (!$this->_isStream) {
|
2015-09-01 22:53:57 +02:00
|
|
|
throw new Zend_Mime_Exception(
|
|
|
|
'Attempt to get a stream from a string part'
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//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)) {
|
2015-09-01 22:53:57 +02:00
|
|
|
throw new Zend_Mime_Exception(
|
|
|
|
'Failed to append quoted-printable filter'
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
break;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
2014-11-13 10:42:49 +01:00
|
|
|
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)) {
|
2015-09-01 22:53:57 +02:00
|
|
|
throw new Zend_Mime_Exception(
|
|
|
|
'Failed to append base64 filter'
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
break;
|
2015-09-01 22:53:57 +02:00
|
|
|
|
2014-11-13 10:42:49 +01:00
|
|
|
default:
|
|
|
|
}
|
2015-09-01 22:53:57 +02:00
|
|
|
|
2014-11-13 10:42:49 +01:00
|
|
|
return $this->_content;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Content of the current Mime Part in the given encoding.
|
|
|
|
*
|
2015-09-01 22:53:57 +02:00
|
|
|
* @param string $EOL Line end; defaults to {@link Zend_Mime::LINEEND}
|
|
|
|
* @throws Zend_Mime_Exception
|
|
|
|
* @return string
|
2014-11-13 10:42:49 +01:00
|
|
|
*/
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
2015-09-01 22:53:57 +02:00
|
|
|
|
2014-11-13 10:42:49 +01:00
|
|
|
/**
|
|
|
|
* Get the RAW unencoded content from this part
|
2015-09-01 22:53:57 +02:00
|
|
|
*
|
2014-11-13 10:42:49 +01:00
|
|
|
* @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
|
|
|
|
*
|
2015-09-01 22:53:57 +02:00
|
|
|
* @param string $EOL Line end; defaults to {@link Zend_Mime::LINEEND}
|
2014-11-13 10:42:49 +01:00
|
|
|
* @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
|
2015-09-01 22:53:57 +02:00
|
|
|
. " boundary=\"" . $this->boundary . '"';
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
2015-09-01 22:53:57 +02:00
|
|
|
$headers[] = array(
|
|
|
|
'Content-Type',
|
|
|
|
$contentType
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
|
|
|
|
if ($this->encoding) {
|
2015-09-01 22:53:57 +02:00
|
|
|
$headers[] = array(
|
|
|
|
'Content-Transfer-Encoding',
|
|
|
|
$this->encoding
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->id) {
|
2015-09-01 22:53:57 +02:00
|
|
|
$headers[] = array(
|
|
|
|
'Content-ID',
|
|
|
|
'<' . $this->id . '>'
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->disposition) {
|
|
|
|
$disposition = $this->disposition;
|
|
|
|
if ($this->filename) {
|
|
|
|
$disposition .= '; filename="' . $this->filename . '"';
|
|
|
|
}
|
2015-09-01 22:53:57 +02:00
|
|
|
$headers[] = array(
|
|
|
|
'Content-Disposition',
|
|
|
|
$disposition
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->description) {
|
2015-09-01 22:53:57 +02:00
|
|
|
$headers[] = array(
|
|
|
|
'Content-Description',
|
|
|
|
$this->description
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->location) {
|
2015-09-01 22:53:57 +02:00
|
|
|
$headers[] = array(
|
|
|
|
'Content-Location',
|
|
|
|
$this->location
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
2015-09-01 22:53:57 +02:00
|
|
|
if ($this->language) {
|
|
|
|
$headers[] = array(
|
|
|
|
'Content-Language',
|
|
|
|
$this->language
|
|
|
|
);
|
2014-11-13 10:42:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $headers;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the headers for this part as a string
|
|
|
|
*
|
2015-09-01 22:53:57 +02:00
|
|
|
* @param string $EOL Line end; defaults to {@link Zend_Mime::LINEEND}
|
|
|
|
* @return string
|
2014-11-13 10:42:49 +01:00
|
|
|
*/
|
|
|
|
public function getHeaders($EOL = Zend_Mime::LINEEND)
|
|
|
|
{
|
|
|
|
$res = '';
|
|
|
|
foreach ($this->getHeadersArray($EOL) as $header) {
|
|
|
|
$res .= $header[0] . ': ' . $header[1] . $EOL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $res;
|
|
|
|
}
|
|
|
|
}
|