Overview

Packages

  • IMP
  • None

Classes

  • IMP
  • IMP_Ajax_Application
  • IMP_Ajax_Imple_ContactAutoCompleter
  • IMP_Ajax_Imple_PassphraseDialog
  • IMP_Ajax_Queue
  • IMP_Api
  • IMP_Auth
  • IMP_Block_Newmail
  • IMP_Block_Summary
  • IMP_Compose
  • IMP_Compose_Exception
  • IMP_Compose_Stationery
  • IMP_Contents
  • IMP_Crypt_Pgp
  • IMP_Crypt_Smime
  • IMP_Dimp
  • IMP_Exception
  • IMP_Factory_AuthImap
  • IMP_Factory_Compose
  • IMP_Factory_Contents
  • IMP_Factory_Flags
  • IMP_Factory_Identity
  • IMP_Factory_Imap
  • IMP_Factory_Imaptree
  • IMP_Factory_Mail
  • IMP_Factory_Mailbox
  • IMP_Factory_MailboxList
  • IMP_Factory_MimeViewer
  • IMP_Factory_Pgp
  • IMP_Factory_Quota
  • IMP_Factory_Search
  • IMP_Factory_Sentmail
  • IMP_Factory_Smime
  • IMP_Filter
  • IMP_Flag_Base
  • IMP_Flag_Imap
  • IMP_Flag_Imap_Answered
  • IMP_Flag_Imap_Deleted
  • IMP_Flag_Imap_Draft
  • IMP_Flag_Imap_Flagged
  • IMP_Flag_Imap_Forwarded
  • IMP_Flag_Imap_Junk
  • IMP_Flag_Imap_NotJunk
  • IMP_Flag_Imap_Seen
  • IMP_Flag_System_Attachment
  • IMP_Flag_System_Encrypted
  • IMP_Flag_System_HighPriority
  • IMP_Flag_System_List
  • IMP_Flag_System_LowPriority
  • IMP_Flag_System_Match_Address
  • IMP_Flag_System_Match_Flag
  • IMP_Flag_System_Match_Header
  • IMP_Flag_System_Personal
  • IMP_Flag_System_Signed
  • IMP_Flag_System_Unseen
  • IMP_Flag_User
  • IMP_Flags
  • IMP_Imap
  • IMP_Imap_Acl
  • IMP_Imap_Exception
  • IMP_Imap_PermanentFlags
  • IMP_Imap_Thread
  • IMP_Imap_Tree
  • IMP_Indices
  • IMP_Indices_Form
  • IMP_LoginTasks_SystemTask_GarbageCollection
  • IMP_LoginTasks_SystemTask_Upgrade
  • IMP_LoginTasks_SystemTask_UpgradeAuth
  • IMP_LoginTasks_Task_Autocreate
  • IMP_LoginTasks_Task_DeleteAttachmentsMonthly
  • IMP_LoginTasks_Task_DeleteSentmailMonthly
  • IMP_LoginTasks_Task_FilterOnLogin
  • IMP_LoginTasks_Task_PurgeSentmail
  • IMP_LoginTasks_Task_PurgeSpam
  • IMP_LoginTasks_Task_PurgeTrash
  • IMP_LoginTasks_Task_RecoverDraft
  • IMP_LoginTasks_Task_RenameSentmailMonthly
  • IMP_Mailbox
  • IMP_Mailbox_List
  • IMP_Mailbox_List_Track
  • IMP_Maillog
  • IMP_Menu_Dimp
  • IMP_Message
  • IMP_Mime_Status
  • IMP_Mime_Viewer_Alternative
  • IMP_Mime_Viewer_Appledouble
  • IMP_Mime_Viewer_Audio
  • IMP_Mime_Viewer_Enriched
  • IMP_Mime_Viewer_Externalbody
  • IMP_Mime_Viewer_Html
  • IMP_Mime_Viewer_Images
  • IMP_Mime_Viewer_Itip
  • IMP_Mime_Viewer_Mdn
  • IMP_Mime_Viewer_Partial
  • IMP_Mime_Viewer_Pdf
  • IMP_Mime_Viewer_Pgp
  • IMP_Mime_Viewer_Plain
  • IMP_Mime_Viewer_Related
  • IMP_Mime_Viewer_Rfc822
  • IMP_Mime_Viewer_Smil
  • IMP_Mime_Viewer_Smime
  • IMP_Mime_Viewer_Status
  • IMP_Mime_Viewer_Vcard
  • IMP_Mime_Viewer_Video
  • IMP_Mime_Viewer_Zip
  • IMP_Notification_Event_Status
  • IMP_Notification_Handler_Decorator_ImapAlerts
  • IMP_Notification_Handler_Decorator_NewmailNotify
  • IMP_Notification_Listener_AjaxStatus
  • Imp_Prefs_Identity
  • IMP_Prefs_Ui
  • IMP_Quota
  • IMP_Quota_Base
  • IMP_Quota_Command
  • IMP_Quota_Hook
  • IMP_Quota_Imap
  • IMP_Quota_Maildir
  • IMP_Quota_Mdaemon
  • IMP_Quota_Mercury32
  • IMP_Quota_Null
  • IMP_Quota_Sql
  • IMP_Search
  • IMP_Search_Element
  • IMP_Search_Element_Attachment
  • IMP_Search_Element_Autogenerated
  • IMP_Search_Element_Bulk
  • IMP_Search_Element_Contacts
  • IMP_Search_Element_Date
  • IMP_Search_Element_Flag
  • IMP_Search_Element_Header
  • IMP_Search_Element_Mailinglist
  • IMP_Search_Element_Or
  • IMP_Search_Element_Personal
  • IMP_Search_Element_Recipient
  • IMP_Search_Element_Size
  • IMP_Search_Element_Text
  • IMP_Search_Element_Within
  • IMP_Search_Filter
  • IMP_Search_Filter_Attachment
  • IMP_Search_Filter_Autogenerated
  • IMP_Search_Filter_Builtin
  • IMP_Search_Filter_Bulk
  • IMP_Search_Filter_Contacts
  • IMP_Search_Filter_Mailinglist
  • IMP_Search_Filter_Personal
  • IMP_Search_Query
  • IMP_Search_Vfolder
  • IMP_Search_Vfolder_Builtin
  • IMP_Search_Vfolder_Vinbox
  • IMP_Search_Vfolder_Vtrash
  • IMP_Sentmail
  • IMP_Sentmail_Base
  • IMP_Sentmail_Null
  • IMP_Sentmail_Sql
  • IMP_Spam
  • IMP_Test
  • IMP_Tree_Flist
  • IMP_Tree_Jquerymobile
  • IMP_Tree_Simplehtml
  • IMP_Ui_Compose
  • IMP_Ui_Editor
  • IMP_Ui_Folder
  • IMP_Ui_Headers
  • IMP_Ui_Imageview
  • IMP_Ui_Mailbox
  • IMP_Ui_Message
  • IMP_Ui_Mimp
  • IMP_Ui_Search
  • IMP_Views_Compose
  • IMP_Views_ListMessages
  • IMP_Views_ShowMessage
  • Overview
  • Package
  • Class
  • Tree
  1: <?php
  2: /**
  3:  * The IMP_Mime_Viewer_Related class handles multipart/related
  4:  * (RFC 2387) messages.
  5:  *
  6:  * Copyright 2002-2012 Horde LLC (http://www.horde.org/)
  7:  *
  8:  * See the enclosed file COPYING for license information (GPL). If you
  9:  * did not receive this file, see http://www.horde.org/licenses/gpl.
 10:  *
 11:  * @author   Michael Slusarz <slusarz@horde.org>
 12:  * @category Horde
 13:  * @license  http://www.horde.org/licenses/gpl GPL
 14:  * @package  IMP
 15:  */
 16: class IMP_Mime_Viewer_Related extends Horde_Mime_Viewer_Base
 17: {
 18:     /**
 19:      */
 20:     protected $_capability = array(
 21:         'full' => true,
 22:         'info' => false,
 23:         'inline' => true,
 24:         'raw' => false
 25:     );
 26: 
 27:     /**
 28:      */
 29:     protected $_metadata = array(
 30:         'compressed' => false,
 31:         'embedded' => false,
 32:         'forceinline' => true
 33:     );
 34: 
 35:     /**
 36:      * The start MIME ID.
 37:      *
 38:      * @var string
 39:      */
 40:     protected $_start;
 41: 
 42:     /**
 43:      */
 44:     protected function _render()
 45:     {
 46:         return $this->_IMPrender(false);
 47:     }
 48: 
 49:     /**
 50:      */
 51:     protected function _renderInline()
 52:     {
 53:         return $this->_IMPrender(true);
 54:     }
 55: 
 56:     /**
 57:      * Render out the currently set contents.
 58:      *
 59:      * @param boolean $inline  Are we viewing inline?
 60:      *
 61:      * @return array  See self::render().
 62:      */
 63:     protected function _IMPrender($inline)
 64:     {
 65:         $related_id = $this->_mimepart->getMimeId();
 66:         $used = array($related_id);
 67: 
 68:         if (!($id = $this->_init($inline))) {
 69:             return array();
 70:         }
 71: 
 72:         $render = $this->getConfigParam('imp_contents')->renderMIMEPart($id, $inline ? IMP_Contents::RENDER_INLINE : IMP_Contents::RENDER_FULL);
 73: 
 74:         if (!$inline) {
 75:             foreach (array_keys($render) as $key) {
 76:                 if (!is_null($render[$key])) {
 77:                     return array($related_id => $render[$key]);
 78:                 }
 79:             }
 80:             return null;
 81:         }
 82: 
 83:         $data_id = null;
 84:         $ret = array_fill_keys(array_keys($this->_mimepart->contentTypeMap()), null);
 85: 
 86:         foreach (array_keys($render) as $val) {
 87:             $ret[$val] = $render[$val];
 88:             if ($ret[$val]) {
 89:                 $data_id = $val;
 90:             }
 91:         }
 92: 
 93:         if (!is_null($data_id)) {
 94:             $this->_mimepart->setMetadata('viewable_part', $data_id);
 95: 
 96:             /* We want the inline display to show multipart/related vs. the
 97:              * viewable MIME part.  This is because a multipart/related part
 98:              * is not downloadable and clicking on the MIME part may not
 99:              * produce the desired result in the full display (i.e. HTML parts
100:              * with related images). */
101:             if ($data_id !== $related_id) {
102:                 $ret[$related_id] = $ret[$data_id];
103:                 $ret[$data_id] = null;
104:             }
105:         }
106: 
107:         /* Fix for broken messages that don't refer to a related CID part
108:          * within the base part. */
109:         if ($cids_used = $this->_mimepart->getMetadata('related_cids_used')) {
110:             $used = array_merge($used, $cids_used);
111:         }
112: 
113:         foreach (array_diff(array_keys($ret), $used) as $val) {
114:             if (($val !== $id) && !Horde_Mime::isChild($id, $val)) {
115:                 $summary = $this->getConfigParam('imp_contents')->getSummary(
116:                     $val,
117:                     IMP_Contents::SUMMARY_SIZE |
118:                     IMP_Contents::SUMMARY_ICON |
119:                     IMP_Contents::SUMMARY_DESCRIP_LINK |
120:                     IMP_Contents::SUMMARY_DOWNLOAD
121:                 );
122: 
123:                 $status = new IMP_Mime_Status(array(
124:                     _("This part contains an attachment that can not be displayed within this part:"),
125:                     implode('&nbsp;', array(
126:                         $summary['icon'],
127:                         $summary['description'],
128:                         $summary['size'],
129:                         $summary['download']
130:                     ))
131:                 ));
132:                 $status->action(IMP_Mime_Status::WARNING);
133: 
134:                 if (isset($ret[$related_id]['status']) &&
135:                     !is_array($ret[$related_id]['status'])) {
136:                     $ret[$related_id]['status'] = array($ret[$related_id]['status']);
137:                 } else {
138:                     $ret[$related_id]['status'] = array();
139:                 }
140:                 $ret[$related_id]['status'][] = $status;
141:             }
142:         }
143: 
144:         return $ret;
145:     }
146: 
147:     /**
148:      * Initialization: determine start MIME ID.
149:      *
150:      * @param boolean $inline  Are we viewing inline?
151:      *
152:      * @return string  The start MIME ID, or null if the part is not viewable.
153:      */
154:     protected function _init($inline)
155:     {
156:         if (!isset($this->_start)) {
157:             $ids = array_keys($this->_mimepart->contentTypeMap());
158:             $related_id = $this->_mimepart->getMimeId();
159:             $cids = array();
160:             $id = null;
161: 
162:             /* Build a list of parts -> CIDs. */
163:             foreach ($ids as $val) {
164:                 if (strcmp($related_id, $val) !== 0) {
165:                     $part = $this->_mimepart->getPart($val);
166:                     $cids[$val] = $part->getContentId();
167:                 }
168:             }
169: 
170:             /* Look at the 'start' parameter to determine which part to start
171:              * with. If no 'start' parameter, use the first part. RFC 2387
172:              * [3.1] */
173:             $start = $this->_mimepart->getContentTypeParameter('start');
174:             if (!empty($start)) {
175:                 $id = array_search($id, $cids);
176:             }
177: 
178:             if (empty($id)) {
179:                 reset($ids);
180:                 $id = next($ids);
181:             }
182: 
183:             /* Set related information in message metadata. */
184:             $this->_mimepart->setMetadata('related_cids', $cids);
185: 
186:             $this->_start = $id;
187:         }
188: 
189:         /* Only display if the start part (normally text/html) can be
190:          * displayed inline -OR- we are viewing this part as an attachment. */
191:         return ($inline && !$this->getConfigParam('imp_contents')->canDisplay($this->_start, IMP_Contents::RENDER_INLINE))
192:             ? null
193:             : $this->_start;
194:     }
195: 
196:     /**
197:      */
198:     public function canRender($mode)
199:     {
200:         return (($mode == 'inline') && !$this->_init(true))
201:             ? false
202:             : parent::canRender($mode);
203:     }
204: 
205: }
206: 
API documentation generated by ApiGen