fix calendar css, take 2. (#213)
[openemr.git] / interface / modules / zend_modules / library / Zend / Mail / Header / HeaderWrap.php
blobdf532edc5fec5741e5efd0fcf67188dedccaf08f
1 <?php
2 /**
3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
8 */
10 namespace Zend\Mail\Header;
12 use Zend\Mail\Headers;
13 use Zend\Mime\Mime;
15 /**
16 * Utility class used for creating wrapped or MIME-encoded versions of header
17 * values.
19 abstract class HeaderWrap
21 /**
22 * Wrap a long header line
24 * @param string $value
25 * @param HeaderInterface $header
26 * @return string
28 public static function wrap($value, HeaderInterface $header)
30 if ($header instanceof UnstructuredInterface) {
31 return static::wrapUnstructuredHeader($value, $header);
32 } elseif ($header instanceof StructuredInterface) {
33 return static::wrapStructuredHeader($value, $header);
35 return $value;
38 /**
39 * Wrap an unstructured header line
41 * Wrap at 78 characters or before, based on whitespace.
43 * @param string $value
44 * @param HeaderInterface $header
45 * @return string
47 protected static function wrapUnstructuredHeader($value, HeaderInterface $header)
49 $encoding = $header->getEncoding();
50 if ($encoding == 'ASCII') {
51 return wordwrap($value, 78, Headers::FOLDING);
53 return static::mimeEncodeValue($value, $encoding, 78);
56 /**
57 * Wrap a structured header line
59 * @param string $value
60 * @param StructuredInterface $header
61 * @return string
63 protected static function wrapStructuredHeader($value, StructuredInterface $header)
65 $delimiter = $header->getDelimiter();
67 $length = strlen($value);
68 $lines = array();
69 $temp = '';
70 for ($i = 0; $i < $length; $i++) {
71 $temp .= $value[$i];
72 if ($value[$i] == $delimiter) {
73 $lines[] = $temp;
74 $temp = '';
77 return implode(Headers::FOLDING, $lines);
80 /**
81 * MIME-encode a value
83 * Performs quoted-printable encoding on a value, setting maximum
84 * line-length to 998.
86 * @param string $value
87 * @param string $encoding
88 * @param int $lineLength maximum line-length, by default 998
89 * @return string Returns the mime encode value without the last line ending
91 public static function mimeEncodeValue($value, $encoding, $lineLength = 998)
93 return Mime::encodeQuotedPrintableHeader($value, $encoding, $lineLength, Headers::EOL);
96 /**
97 * MIME-decode a value
99 * Performs quoted-printable decoding on a value.
101 * @param string $value
102 * @return string Returns the mime encode value without the last line ending
104 public static function mimeDecodeValue($value)
106 $decodedValue = iconv_mime_decode($value, ICONV_MIME_DECODE_CONTINUE_ON_ERROR, 'UTF-8');
108 return $decodedValue;
112 * Test if is possible apply MIME-encoding
114 * @param string $value
115 * @return bool
117 public static function canBeEncoded($value)
119 $encoded = iconv_mime_encode('x-test', $value, array('scheme' => 'Q'));
121 return (false !== $encoded);