當前位置: 首頁>>代碼示例>>PHP>>正文


PHP mapi_message_savechanges函數代碼示例

本文整理匯總了PHP中mapi_message_savechanges函數的典型用法代碼示例。如果您正苦於以下問題:PHP mapi_message_savechanges函數的具體用法?PHP mapi_message_savechanges怎麽用?PHP mapi_message_savechanges使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了mapi_message_savechanges函數的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: ImportMessageChange

 /**
  * Imports a single message
  *
  * @param string        $id
  * @param SyncObject    $message
  *
  * @access public
  * @return boolean/string - failure / id of message
  * @throws StatusException
  */
 public function ImportMessageChange($id, $message)
 {
     $parentsourcekey = $this->folderid;
     if ($id) {
         $sourcekey = hex2bin($id);
     }
     $flags = 0;
     $props = array();
     $props[PR_PARENT_SOURCE_KEY] = $parentsourcekey;
     // set the PR_SOURCE_KEY if available or mark it as new message
     if ($id) {
         $props[PR_SOURCE_KEY] = $sourcekey;
         // check for conflicts
         $this->lazyLoadConflicts();
         if ($this->memChanges->IsChanged($id)) {
             if ($this->flags & SYNC_CONFLICT_OVERWRITE_PIM) {
                 // in these cases the status SYNC_STATUS_CONFLICTCLIENTSERVEROBJECT should be returned, so the mobile client can inform the end user
                 throw new StatusException(sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Conflict detected. Data from PIM will be dropped! Server overwrites PIM. User is informed.", $id, get_class($message)), SYNC_STATUS_CONFLICTCLIENTSERVEROBJECT, null, LOGLEVEL_INFO);
                 return false;
             } else {
                 ZLog::Write(LOGLEVEL_INFO, sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Conflict detected. Data from Server will be dropped! PIM overwrites server.", $id, get_class($message)));
             }
         }
         if ($this->memChanges->IsDeleted($id)) {
             ZLog::Write(LOGLEVEL_INFO, sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Conflict detected. Data from PIM will be dropped! Object was deleted on server.", $id, get_class($message)));
             return false;
         }
     } else {
         $flags = SYNC_NEW_MESSAGE;
     }
     if (mapi_importcontentschanges_importmessagechange($this->importer, $props, $flags, $mapimessage)) {
         $this->mapiprovider->SetMessage($mapimessage, $message);
         mapi_message_savechanges($mapimessage);
         if (mapi_last_hresult()) {
             throw new StatusException(sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Error, mapi_message_savechanges() failed: 0x%X", $id, get_class($message), mapi_last_hresult()), SYNC_STATUS_SYNCCANNOTBECOMPLETED);
         }
         $sourcekeyprops = mapi_getprops($mapimessage, array(PR_SOURCE_KEY));
         return bin2hex($sourcekeyprops[PR_SOURCE_KEY]);
     } else {
         throw new StatusException(sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Error updating object: 0x%X", $id, get_class($message), mapi_last_hresult()), SYNC_STATUS_OBJECTNOTFOUND);
     }
 }
開發者ID:netconstructor,項目名稱:sogosync,代碼行數:52,代碼來源:importer.php

示例2: submitMeetingRequest


//.........這裏部分代碼省略.........
     if ($prefix && isset($newmessageprops[PR_SUBJECT])) {
         $newmessageprops[PR_SUBJECT] = $prefix . $newmessageprops[PR_SUBJECT];
     }
     mapi_setprops($new, $newmessageprops);
     // Copy attachments
     $this->replaceAttachments($message, $new, $copyExceptions);
     // Retrieve only those recipient who should receive this meeting request.
     $stripResourcesRestriction = array(RES_AND, array(array(RES_BITMASK, array(ULTYPE => BMR_EQZ, ULPROPTAG => PR_RECIPIENT_FLAGS, ULMASK => recipExceptionalDeleted)), array(RES_BITMASK, array(ULTYPE => BMR_EQZ, ULPROPTAG => PR_RECIPIENT_FLAGS, ULMASK => recipOrganizer))));
     // In direct-booking mode, resources do not receive a meeting request
     if ($this->enableDirectBooking) {
         $stripResourcesRestriction[1][] = array(RES_PROPERTY, array(RELOP => RELOP_NE, ULPROPTAG => PR_RECIPIENT_TYPE, VALUE => array(PR_RECIPIENT_TYPE => MAPI_BCC)));
     }
     $recipienttable = mapi_message_getrecipienttable($message);
     $recipients = mapi_table_queryallrows($recipienttable, $this->recipprops, $stripResourcesRestriction);
     if ($basedate && empty($recipients)) {
         // Retrieve full list
         $recipienttable = mapi_message_getrecipienttable($this->message);
         $recipients = mapi_table_queryallrows($recipienttable, $this->recipprops);
         // Save recipients in exceptions
         mapi_message_modifyrecipients($message, MODRECIP_ADD, $recipients);
         // Now retrieve only those recipient who should receive this meeting request.
         $recipients = mapi_table_queryallrows($recipienttable, $this->recipprops, $stripResourcesRestriction);
     }
     //@TODO: handle nonAcceptingResources
     /**
      * Add resource recipients that did not automatically accept the meeting request.
      * (note: meaning that they did not decline the meeting request)
      */
     /*
             for($i=0;$i<count($this->nonAcceptingResources);$i++){
                 $recipients[] = $this->nonAcceptingResources[$i];
             }*/
     if (!empty($recipients)) {
         // Strip out the sender/"owner" recipient
         mapi_message_modifyrecipients($new, MODRECIP_ADD, $recipients);
         // Set some properties that are different in the sent request than
         // in the item in our calendar
         // we should store busystatus value to intendedbusystatus property, because busystatus for outgoing meeting request
         // should always be fbTentative
         $newmessageprops[$this->proptags['intendedbusystatus']] = isset($newmessageprops[$this->proptags['busystatus']]) ? $newmessageprops[$this->proptags['busystatus']] : $messageprops[$this->proptags['busystatus']];
         $newmessageprops[$this->proptags['busystatus']] = fbTentative;
         // The default status when not accepted
         $newmessageprops[$this->proptags['responsestatus']] = olResponseNotResponded;
         // The recipient has not responded yet
         $newmessageprops[$this->proptags['attendee_critical_change']] = time();
         $newmessageprops[$this->proptags['owner_critical_change']] = time();
         $newmessageprops[$this->proptags['meetingtype']] = mtgRequest;
         if ($cancel) {
             $newmessageprops[PR_MESSAGE_CLASS] = "IPM.Schedule.Meeting.Canceled";
             $newmessageprops[$this->proptags['meetingstatus']] = olMeetingCanceled;
             // It's a cancel request
             $newmessageprops[$this->proptags['busystatus']] = fbFree;
             // set the busy status as free
         } else {
             $newmessageprops[PR_MESSAGE_CLASS] = "IPM.Schedule.Meeting.Request";
             $newmessageprops[$this->proptags['meetingstatus']] = olMeetingReceived;
             // The recipient is receiving the request
         }
         mapi_setprops($new, $newmessageprops);
         mapi_message_savechanges($new);
         // Submit message to non-resource recipients
         mapi_message_submitmessage($new);
     }
     // Send cancellation to deleted attendees
     if ($deletedRecips && !empty($deletedRecips)) {
         $new = $this->createOutgoingMessage();
         mapi_message_modifyrecipients($new, MODRECIP_ADD, $deletedRecips);
         $newmessageprops[PR_MESSAGE_CLASS] = "IPM.Schedule.Meeting.Canceled";
         $newmessageprops[$this->proptags['meetingstatus']] = olMeetingCanceled;
         // It's a cancel request
         $newmessageprops[$this->proptags['busystatus']] = fbFree;
         // set the busy status as free
         $newmessageprops[PR_IMPORTANCE] = IMPORTANCE_HIGH;
         // HIGH Importance
         if (isset($newmessageprops[PR_SUBJECT])) {
             $newmessageprops[PR_SUBJECT] = _('Canceled: ') . $newmessageprops[PR_SUBJECT];
         }
         mapi_setprops($new, $newmessageprops);
         mapi_message_savechanges($new);
         // Submit message to non-resource recipients
         mapi_message_submitmessage($new);
     }
     // Set properties on meeting object in calendar
     // Set requestsent to 'true' (turns on 'tracking', etc)
     $props = array();
     $props[$this->proptags['meetingstatus']] = olMeeting;
     $props[$this->proptags['responsestatus']] = olResponseOrganized;
     $props[$this->proptags['requestsent']] = !empty($recipients) || $this->includesResources && !$this->errorSetResource;
     $props[$this->proptags['attendee_critical_change']] = time();
     $props[$this->proptags['owner_critical_change']] = time();
     $props[$this->proptags['meetingtype']] = mtgRequest;
     // save the new updatecounter to exception/recurring series/normal meeting
     $props[$this->proptags['updatecounter']] = $newmessageprops[$this->proptags['updatecounter']];
     // PR_START_DATE and PR_END_DATE will be used by outlook to show the position in the calendar
     $props[PR_START_DATE] = $messageprops[$this->proptags['startdate']];
     $props[PR_END_DATE] = $messageprops[$this->proptags['duedate']];
     mapi_setprops($message, $props);
     // saving of these properties on calendar item should be handled by caller function
     // based on sending meeting request was successfull or not
 }
開發者ID:netconstructor,項目名稱:sogosync,代碼行數:101,代碼來源:class.meetingrequest.php

示例3: createExceptionAttachment

 /**
  * Function which saves the exception data in an attachment.
  * @param array $exception_props the exception data (like any other MAPI appointment)
  * @param array $exception_recips list of recipients
  * @param mapi_message $copy_attach_from mapi message from which attachments should be copied
  * @return array properties of the exception
  */
 function createExceptionAttachment($exception_props, $exception_recips = array(), $copy_attach_from = false)
 {
     // Create new attachment.
     $attachment = mapi_message_createattach($this->message);
     $props = array();
     $props[PR_ATTACHMENT_FLAGS] = 2;
     $props[PR_ATTACHMENT_HIDDEN] = true;
     $props[PR_ATTACHMENT_LINKID] = 0;
     $props[PR_ATTACH_FLAGS] = 0;
     $props[PR_ATTACH_METHOD] = 5;
     $props[PR_DISPLAY_NAME] = "Exception";
     $props[PR_EXCEPTION_STARTTIME] = $this->fromGMT($this->tz, $exception_props[$this->proptags["startdate"]]);
     $props[PR_EXCEPTION_ENDTIME] = $this->fromGMT($this->tz, $exception_props[$this->proptags["duedate"]]);
     mapi_message_setprops($attachment, $props);
     $imessage = mapi_attach_openobj($attachment, MAPI_CREATE | MAPI_MODIFY);
     if ($copy_attach_from) {
         $attachmentTable = mapi_message_getattachmenttable($copy_attach_from);
         if ($attachmentTable) {
             $attachments = mapi_table_queryallrows($attachmentTable, array(PR_ATTACH_NUM, PR_ATTACH_SIZE, PR_ATTACH_LONG_FILENAME, PR_ATTACHMENT_HIDDEN, PR_DISPLAY_NAME, PR_ATTACH_METHOD));
             foreach ($attachments as $attach_props) {
                 $attach_old = mapi_message_openattach($copy_attach_from, (int) $attach_props[PR_ATTACH_NUM]);
                 $attach_newResourceMsg = mapi_message_createattach($imessage);
                 mapi_copyto($attach_old, array(), array(), $attach_newResourceMsg, 0);
                 mapi_savechanges($attach_newResourceMsg);
             }
         }
     }
     $props = $props + $exception_props;
     // FIXME: the following piece of code is written to fix the creation
     // of an exception. This is only a quickfix as it is not yet possible
     // to change an existing exception.
     // remove mv properties when needed
     foreach ($props as $propTag => $propVal) {
         if ((mapi_prop_type($propTag) & MV_FLAG) == MV_FLAG && is_null($propVal)) {
             unset($props[$propTag]);
         }
     }
     mapi_message_setprops($imessage, $props);
     $this->setExceptionRecipients($imessage, $exception_recips, true);
     mapi_message_savechanges($imessage);
     mapi_message_savechanges($attachment);
 }
開發者ID:EGroupware,項目名稱:z-push,代碼行數:49,代碼來源:class.recurrence.php

示例4: SendMail


//.........這裏部分代碼省略.........
             if (!isset($fwmessage) || !$fwmessage) {
                 throw new StatusException(sprintf("ZarafaBackend->SendMail(): Could not open message id '%s' in folder id '%s' to be replied/forwarded: 0x%X", $sm->source->itemid, $sm->source->folderid, mapi_last_hresult()), SYNC_COMMONSTATUS_ITEMNOTFOUND);
             }
             //update icon when forwarding or replying message
             if ($sm->forwardflag) {
                 mapi_setprops($fwmessage, array(PR_ICON_INDEX => 262));
             } elseif ($sm->replyflag) {
                 mapi_setprops($fwmessage, array(PR_ICON_INDEX => 261));
             }
             mapi_savechanges($fwmessage);
             // only attach the original message if the mobile does not send it itself
             if (!isset($sm->replacemime)) {
                 // get message's body in order to append forward or reply text
                 $body = MAPIUtils::readPropStream($mapimessage, PR_BODY);
                 $bodyHtml = MAPIUtils::readPropStream($mapimessage, PR_HTML);
                 $cpid = mapi_getprops($fwmessage, array($sendMailProps["internetcpid"]));
                 if ($sm->forwardflag) {
                     // attach the original attachments to the outgoing message
                     $this->copyAttachments($mapimessage, $fwmessage);
                 }
                 if (strlen($body) > 0) {
                     $fwbody = MAPIUtils::readPropStream($fwmessage, PR_BODY);
                     $fwbody = isset($cpid[$sendMailProps["internetcpid"]]) ? Utils::ConvertCodepageStringToUtf8($cpid[$sendMailProps["internetcpid"]], $fwbody) : w2u($fwbody);
                     $mapiprops[$sendMailProps["body"]] = $body . "\r\n\r\n" . $fwbody;
                 }
                 if (strlen($bodyHtml) > 0) {
                     $fwbodyHtml = MAPIUtils::readPropStream($fwmessage, PR_HTML);
                     $fwbodyHtml = isset($cpid[$sendMailProps["internetcpid"]]) ? Utils::ConvertCodepageStringToUtf8($cpid[$sendMailProps["internetcpid"]], $fwbodyHtml) : w2u($fwbodyHtml);
                     $mapiprops[$sendMailProps["html"]] = $bodyHtml . "<br><br>" . $fwbodyHtml;
                 }
             }
         }
         mapi_setprops($mapimessage, $mapiprops);
         mapi_message_savechanges($mapimessage);
         mapi_message_submitmessage($mapimessage);
         $hr = mapi_last_hresult();
         if ($hr) {
             throw new StatusException(sprintf("ZarafaBackend->SendMail(): Error saving/submitting the message to the Outbox: 0x%X", mapi_last_hresult()), SYNC_COMMONSTATUS_MAILSUBMISSIONFAILED);
         }
         ZLog::Write(LOGLEVEL_DEBUG, "ZarafaBackend->SendMail(): email submitted");
         return true;
     }
     $mapiprops[$sendMailProps["subject"]] = u2wi(isset($message->headers["subject"]) ? $message->headers["subject"] : "");
     $mapiprops[$sendMailProps["messageclass"]] = "IPM.Note";
     $mapiprops[$sendMailProps["deliverytime"]] = time();
     if (isset($message->headers["x-priority"])) {
         $this->getImportanceAndPriority($message->headers["x-priority"], $mapiprops, $sendMailProps);
     }
     $this->addRecipients($message->headers, $mapimessage);
     // Loop through message subparts.
     $body = "";
     $body_html = "";
     if ($message->ctype_primary == "multipart" && ($message->ctype_secondary == "mixed" || $message->ctype_secondary == "alternative")) {
         $mparts = $message->parts;
         for ($i = 0; $i < count($mparts); $i++) {
             $part = $mparts[$i];
             // palm pre & iPhone send forwarded messages in another subpart which are also parsed
             if ($part->ctype_primary == "multipart" && ($part->ctype_secondary == "mixed" || $part->ctype_secondary == "alternative" || $part->ctype_secondary == "related")) {
                 foreach ($part->parts as $spart) {
                     $mparts[] = $spart;
                 }
                 continue;
             }
             // standard body
             if ($part->ctype_primary == "text" && $part->ctype_secondary == "plain" && isset($part->body) && (!isset($part->disposition) || $part->disposition != "attachment")) {
                 $body .= u2wi($part->body);
開發者ID:BackupTheBerlios,項目名稱:z-push-svn,代碼行數:67,代碼來源:zarafa.php

示例5: ImportMessageChange

 function ImportMessageChange($id, $message)
 {
     $parentsourcekey = $this->_folderid;
     if ($id) {
         $sourcekey = hex2bin($id);
     }
     $flags = 0;
     $props = array();
     $props[PR_PARENT_SOURCE_KEY] = $parentsourcekey;
     // set the PR_SOURCE_KEY if available or mark it as new message
     if ($id) {
         $props[PR_SOURCE_KEY] = $sourcekey;
     } else {
         $flags = SYNC_NEW_MESSAGE;
     }
     if (mapi_importcontentschanges_importmessagechange($this->importer, $props, $flags, $mapimessage)) {
         $this->_setMessage($mapimessage, $message);
         mapi_message_savechanges($mapimessage);
         $sourcekeyprops = mapi_getprops($mapimessage, array(PR_SOURCE_KEY));
     } else {
         debugLog("Unable to update object {$id}:" . sprintf("%x", mapi_last_hresult()));
         return false;
     }
     return bin2hex($sourcekeyprops[PR_SOURCE_KEY]);
 }
開發者ID:jkreska,項目名稱:test1,代碼行數:25,代碼來源:ics.php

示例6: ImportMessageChange

 function ImportMessageChange($id, $message)
 {
     $parentsourcekey = $this->_folderid;
     if ($id) {
         $sourcekey = hex2bin($id);
     }
     $flags = 0;
     $props = array();
     $props[PR_PARENT_SOURCE_KEY] = $parentsourcekey;
     // set the PR_SOURCE_KEY if available or mark it as new message
     if ($id) {
         $props[PR_SOURCE_KEY] = $sourcekey;
         // check for conflicts
         $this->_lazyLoadConflicts();
         if ($this->_memChanges->isChanged($id)) {
             if ($this->_flags & SYNC_CONFLICT_OVERWRITE_PIM) {
                 debugLog("Conflict detected. Data from PIM will be dropped! Server overwrites PIM.");
                 return false;
             } else {
                 debugLog("Conflict detected. Data from Server will be dropped! PIM overwrites server.");
             }
         }
         if ($this->_memChanges->isDeleted($id)) {
             debugLog("Conflict detected. Data from PIM will be dropped! Object was deleted on server.");
             return false;
         }
     } else {
         $flags = SYNC_NEW_MESSAGE;
     }
     if (mapi_importcontentschanges_importmessagechange($this->importer, $props, $flags, $mapimessage)) {
         $this->_setMessage($mapimessage, $message);
         mapi_message_savechanges($mapimessage);
         $sourcekeyprops = mapi_getprops($mapimessage, array(PR_SOURCE_KEY));
     } else {
         debugLog("Unable to update object {$id}:" . sprintf("%x", mapi_last_hresult()));
         return false;
     }
     return bin2hex($sourcekeyprops[PR_SOURCE_KEY]);
 }
開發者ID:nnaannoo,項目名稱:paskot,代碼行數:39,代碼來源:ics.php

示例7: ImportMessageChange

 function ImportMessageChange($id, &$message)
 {
     $parentsourcekey = $this->_folderid;
     if ($id) {
         $sourcekey = hex2bin($id);
     }
     $flags = 0;
     $props = array();
     $props[PR_PARENT_SOURCE_KEY] = $parentsourcekey;
     // set the PR_SOURCE_KEY if available or mark it as new message
     if ($id) {
         $props[PR_SOURCE_KEY] = $sourcekey;
         // check for conflicts
         if ($this->_memChanges->isChanged($id)) {
             if ($this->_flags == SYNC_CONFLICT_OVERWRITE_PIM) {
                 debugLog("Conflict detected. Data from PIM will be dropped! Server overwrites PIM.");
                 return false;
             } else {
                 debugLog("Conflict detected. Data from Server will be dropped! PIM overwrites server.");
             }
         }
         if ($this->_memChanges->isDeleted($id)) {
             debugLog("Conflict detected. Data from PIM will be dropped! Object was deleted on server.");
             return false;
         }
     } else {
         $flags = SYNC_NEW_MESSAGE;
     }
     $class = strtolower(get_class($message));
     debugLog("Class is " . $class . " Flags " . ($flags != SYNC_NEW_MESSAGE ? " not SYNC_NEW_MESSAGE " : " SYNC_NEW_MESSAGE"));
     // SMS Initial Sync deduplication of items
     if ($class == "syncsms") {
         debugLog("Class is SMS and _md5tosrvid contains values. Deduplication routine starting");
         if (preg_match('/(\\"(.*)\\" ){0,1}\\[(.*):(.*)\\]$/', $message->to, $addrparts)) {
             $name = $addrparts[2] == "" ? $addrparts[4] : $addrparts[2];
             $addrtype = $addrparts[3];
             $email_address = $addrparts[4];
             $message->to = "\"" . $name . "\" [MOBILE:" . $email_address . "]";
         }
         if (preg_match('/(\\"(.*)\\" ){0,1}\\[(.*):(.*)\\]$/', $message->from, $addrparts)) {
             $name = $addrparts[2] == "" ? $addrparts[4] : $addrparts[2];
             $addrtype = $addrparts[3];
             $email_address = $addrparts[4];
             $message->from = "\"" . $name . "\" [MOBILE:" . $email_address . "]";
         }
         if (preg_match('/(\\"(.*)\\" ){0,1}\\[(.*):(.*)\\]$/', $message->cc, $addrparts)) {
             $name = $addrparts[2] == "" ? $addrparts[4] : $addrparts[2];
             $addrtype = $addrparts[3];
             $email_address = $addrparts[4];
             $message->cc = "\"" . $name . "\" [MOBILE:" . $email_address . "]";
         }
         debugLog(bin2hex(str_replace("\n", "\r\n", str_replace("\r\n", "\n", strval($message->airsyncbasebody->data)))));
         debugLog(bin2hex(strval($message->from)));
         debugLog(bin2hex(strval($message->cc)));
         debugLog(bin2hex(strval($message->to)));
         //		debugLog("ImportMessageChange Message: ".print_r($message,true));
         $md5msg = array('datereceived' => isset($message->datereceived) ? strval($message->datereceived) : '', 'importance' => isset($message->importance) ? strval($message->importance) : '', 'messageclass' => isset($message->messageclass) ? strval($message->messageclass) : 'IPM.Note.Mobile.SMS', 'to' => isset($message->to) ? strval($message->to) : '', 'cc' => isset($message->cc) ? strval($message->cc) : '', 'from' => isset($message->from) ? strval($message->from) : '', 'internetcpid' => isset($message->internetcpid) ? strval($message->internetcpid) : '1252', 'body' => isset($message->airsyncbasebody->data) ? str_replace("\n", "\r\n", str_replace("\r\n", "\n", strval($message->airsyncbasebody->data))) : '');
         $msgmd5 = md5(serialize($md5msg));
         unset($md5msg);
         debugLog("MD5 SMS Message is {$msgmd5}");
         debugLog(print_r($this->_memChanges->_md5tosrvid, true));
         if (($dupcheck = $this->_memChanges->isDuplicate($msgmd5)) !== false) {
             debugLog("Possible message duplicate found!");
             $ret['sourcekey'] = $dupcheck['serverid'];
             $ret['convid'] = $dupcheck['conversationid'];
             $ret['convidx'] = $dupcheck['conversationindex'];
             return $ret;
         } else {
             debugLog("isDuplicate returned false!");
         }
     }
     if ($class != "syncsms" || $class == "syncsms" && $flags != SYNC_NEW_MESSAGE) {
         debugLog("Update Item using mapi_importcontentschanges_importmessagechange.");
         if (mapi_importcontentschanges_importmessagechange($this->importer, $props, $flags, $mapimessage)) {
             $this->_setMessage($mapimessage, $message);
             mapi_message_savechanges($mapimessage);
             $sourcekeyprops = mapi_getprops($mapimessage, array(PR_SOURCE_KEY));
             if (CONVERSATIONINDEX == true) {
                 $convidxprops = mapi_getprops($mapimessage, array(PR_CONVERSATION_INDEX));
             }
         } else {
             debugLog("Unable to update object {$id}:" . sprintf("%x", mapi_last_hresult()));
             return false;
         }
     } else {
         debugLog("New SMS detected. Create it by mapi_folder_createmessage");
         $mapimessage = mapi_folder_createmessage($this->_folder);
         if ($mapimessage) {
             $this->_setMessage($mapimessage, $message);
             mapi_message_savechanges($mapimessage);
             $sourcekeyprops = mapi_getprops($mapimessage, array(PR_SOURCE_KEY));
             if (CONVERSATIONINDEX == true) {
                 $convidxprops = mapi_getprops($mapimessage, array(PR_CONVERSATION_INDEX));
             }
         } else {
             debugLog("Unable to create object {$id}:" . sprintf("%x", mapi_last_hresult()));
             return false;
         }
     }
     if (isset($convidxprops) && is_array($convidxprops) && isset($convidxprops[PR_CONVERSATION_INDEX]) && strlen($convidxprops[PR_CONVERSATION_INDEX]) >= 22) {
//.........這裏部分代碼省略.........
開發者ID:netconstructor,項目名稱:activesync,代碼行數:101,代碼來源:ics.php

示例8: ImportMessageChange

 /**
  * Imports a single message
  *
  * @param string        $id
  * @param SyncObject    $message
  *
  * @access public
  * @return boolean/string - failure / id of message
  * @throws StatusException
  */
 public function ImportMessageChange($id, $message)
 {
     $flags = 0;
     $props = array();
     $props[PR_PARENT_SOURCE_KEY] = $this->folderid;
     // set the PR_SOURCE_KEY if available or mark it as new message
     if ($id) {
         list(, $sk) = Utils::SplitMessageId($id);
         $props[PR_SOURCE_KEY] = hex2bin($sk);
         // on editing an existing message, check if it is in the synchronization interval
         if (!$this->isMessageInSyncInterval($sk)) {
             throw new StatusException(sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Message is outside the sync interval. Data not saved.", $id, get_class($message)), SYNC_STATUS_SYNCCANNOTBECOMPLETED);
         }
         // check for conflicts
         $this->lazyLoadConflicts();
         if ($this->memChanges->IsChanged($id)) {
             if ($this->flags & SYNC_CONFLICT_OVERWRITE_PIM) {
                 // in these cases the status SYNC_STATUS_CONFLICTCLIENTSERVEROBJECT should be returned, so the mobile client can inform the end user
                 throw new StatusException(sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Conflict detected. Data from PIM will be dropped! Server overwrites PIM. User is informed.", $id, get_class($message)), SYNC_STATUS_CONFLICTCLIENTSERVEROBJECT, null, LOGLEVEL_INFO);
                 return false;
             } else {
                 ZLog::Write(LOGLEVEL_INFO, sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Conflict detected. Data from Server will be dropped! PIM overwrites server.", $id, get_class($message)));
             }
         }
         if ($this->memChanges->IsDeleted($id)) {
             ZLog::Write(LOGLEVEL_INFO, sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Conflict detected. Data from PIM will be dropped! Object was deleted on server.", $id, get_class($message)));
             return false;
         }
         // KOE ZP-990: OL updates the deleted category which causes a race condition if more than one KOE is connected to that user
         if (ZPush::GetDeviceManager()->IsKoe() && KOE_CAPABILITY_RECEIVEFLAGS && $message instanceof SyncMail && !isset($message->flag) && isset($message->categories)) {
             // check if the categories changed
             $mapiCategories = $this->mapiprovider->GetMessageCategories($props[PR_PARENT_SOURCE_KEY], $props[PR_SOURCE_KEY]);
             if (empty($message->categories) && empty($mapiCategories) || is_array($mapiCategories) && count(array_diff($mapiCategories, $message->categories)) == 0 && count(array_diff($message->categories, $mapiCategories)) == 0) {
                 ZLog::Write(LOGLEVEL_DEBUG, "ImportChangesICS->ImportMessageChange(): KOE update of flag categories. Ignoring incoming update.");
                 return $id;
             }
         }
     } else {
         $flags = SYNC_NEW_MESSAGE;
     }
     if (mapi_importcontentschanges_importmessagechange($this->importer, $props, $flags, $mapimessage)) {
         $this->mapiprovider->SetMessage($mapimessage, $message);
         mapi_message_savechanges($mapimessage);
         if (mapi_last_hresult()) {
             throw new StatusException(sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Error, mapi_message_savechanges() failed: 0x%X", $id, get_class($message), mapi_last_hresult()), SYNC_STATUS_SYNCCANNOTBECOMPLETED);
         }
         $sourcekeyprops = mapi_getprops($mapimessage, array(PR_SOURCE_KEY));
         return $this->prefix . bin2hex($sourcekeyprops[PR_SOURCE_KEY]);
     } else {
         throw new StatusException(sprintf("ImportChangesICS->ImportMessageChange('%s','%s'): Error updating object: 0x%X", $id, get_class($message), mapi_last_hresult()), SYNC_STATUS_OBJECTNOTFOUND);
     }
 }
開發者ID:EGroupware,項目名稱:z-push,代碼行數:62,代碼來源:importer.php

示例9: SendMail


//.........這裏部分代碼省略.........
     if (isset($props[$sendMailProps["internetcpid"]]) && $props[$sendMailProps["internetcpid"]] != INTERNET_CPID_UTF8) {
         ZLog::Write(LOGLEVEL_DEBUG, sprintf("Sent email cpid is not unicode (%d). Set it to unicode and convert email body.", $props[$sendMailProps["internetcpid"]]));
         $mapiprops[$sendMailProps["internetcpid"]] = INTERNET_CPID_UTF8;
         $body = MAPIUtils::readPropStream($mapimessage, PR_BODY);
         $body = Utils::ConvertCodepageStringToUtf8($props[$sendMailProps["internetcpid"]], $body);
         $mapiprops[$sendMailProps["body"]] = $body;
         $bodyHtml = MAPIUtils::readPropStream($mapimessage, PR_HTML);
         $bodyHtml = Utils::ConvertCodepageStringToUtf8($props[$sendMailProps["internetcpid"]], $bodyHtml);
         $mapiprops[$sendMailProps["html"]] = $bodyHtml;
         mapi_setprops($mapimessage, $mapiprops);
     }
     if (stripos($props[PR_MESSAGE_CLASS], "IPM.Schedule.Meeting.Resp.") === 0) {
         // search for calendar items using goid
         $mr = new Meetingrequest($this->store, $mapimessage);
         $appointments = $mr->findCalendarItems($props[$meetingRequestProps["goidtag"]]);
         if (is_array($appointments) && !empty($appointments)) {
             $app = mapi_msgstore_openentry($this->store, $appointments[0]);
             $appprops = mapi_getprops($app, array($meetingRequestProps["appSeqNr"]));
             if (isset($appprops[$meetingRequestProps["appSeqNr"]]) && $appprops[$meetingRequestProps["appSeqNr"]]) {
                 $mapiprops[$meetingRequestProps["appSeqNr"]] = $appprops[$meetingRequestProps["appSeqNr"]];
                 ZLog::Write(LOGLEVEL_DEBUG, sprintf("Set sequence number to:%d", $appprops[$meetingRequestProps["appSeqNr"]]));
             }
         }
     }
     // Delete the PR_SENT_REPRESENTING_* properties because some android devices
     // do not send neither From nor Sender header causing empty PR_SENT_REPRESENTING_NAME and
     // PR_SENT_REPRESENTING_EMAIL_ADDRESS properties and "broken" PR_SENT_REPRESENTING_ENTRYID
     // which results in spooler not being able to send the message.
     // @see http://jira.zarafa.com/browse/ZP-85
     mapi_deleteprops($mapimessage, array($sendMailProps["sentrepresentingname"], $sendMailProps["sentrepresentingemail"], $sendMailProps["representingentryid"], $sendMailProps["sentrepresentingaddt"], $sendMailProps["sentrepresentinsrchk"]));
     if (isset($sm->source->itemid) && $sm->source->itemid) {
         // answering an email in a public/shared folder
         if (!$this->Setup(ZPush::GetAdditionalSyncFolderStore($sm->source->folderid))) {
             throw new StatusException(sprintf("ZarafaBackend->SendMail() could not Setup() the backend for folder id '%s'", $sm->source->folderid), SYNC_COMMONSTATUS_SERVERERROR);
         }
         $entryid = mapi_msgstore_entryidfromsourcekey($this->store, hex2bin($sm->source->folderid), hex2bin($sm->source->itemid));
         if ($entryid) {
             $fwmessage = mapi_msgstore_openentry($this->store, $entryid);
         }
         if (!isset($fwmessage) || !$fwmessage) {
             throw new StatusException(sprintf("ZarafaBackend->SendMail(): Could not open message id '%s' in folder id '%s' to be replied/forwarded: 0x%X", $sm->source->itemid, $sm->source->folderid, mapi_last_hresult()), SYNC_COMMONSTATUS_ITEMNOTFOUND);
         }
         //update icon when forwarding or replying message
         if ($sm->forwardflag) {
             mapi_setprops($fwmessage, array(PR_ICON_INDEX => 262));
         } elseif ($sm->replyflag) {
             mapi_setprops($fwmessage, array(PR_ICON_INDEX => 261));
         }
         mapi_savechanges($fwmessage);
         // only attach the original message if the mobile does not send it itself
         if (!isset($sm->replacemime)) {
             // get message's body in order to append forward or reply text
             if (!isset($body)) {
                 $body = MAPIUtils::readPropStream($mapimessage, PR_BODY);
             }
             if (!isset($bodyHtml)) {
                 $bodyHtml = MAPIUtils::readPropStream($mapimessage, PR_HTML);
             }
             $cpid = mapi_getprops($fwmessage, array($sendMailProps["internetcpid"]));
             if ($sm->forwardflag) {
                 // attach the original attachments to the outgoing message
                 $this->copyAttachments($mapimessage, $fwmessage);
             }
             // regarding the conversion @see ZP-470
             if (strlen($body) > 0) {
                 $fwbody = MAPIUtils::readPropStream($fwmessage, PR_BODY);
                 // if only the old message's cpid is set, convert from old charset to utf-8
                 if (isset($cpid[$sendMailProps["internetcpid"]]) && $cpid[$sendMailProps["internetcpid"]] != INTERNET_CPID_UTF8) {
                     ZLog::Write(LOGLEVEL_DEBUG, sprintf("ZarafaBackend->SendMail(): convert plain forwarded message charset (only fw set) from '%s' to '65001'", $cpid[$sendMailProps["internetcpid"]]));
                     $fwbody = Utils::ConvertCodepageStringToUtf8($cpid[$sendMailProps["internetcpid"]], $fwbody);
                 } else {
                     ZLog::Write(LOGLEVEL_DEBUG, "ZarafaBackend->SendMail(): no charset conversion done for plain forwarded message");
                     $fwbody = w2u($fwbody);
                 }
                 $mapiprops[$sendMailProps["body"]] = $body . "\r\n\r\n" . $fwbody;
             }
             if (strlen($bodyHtml) > 0) {
                 $fwbodyHtml = MAPIUtils::readPropStream($fwmessage, PR_HTML);
                 // if only new message's cpid is set, convert to UTF-8
                 if (isset($cpid[$sendMailProps["internetcpid"]]) && $cpid[$sendMailProps["internetcpid"]] != INTERNET_CPID_UTF8) {
                     ZLog::Write(LOGLEVEL_DEBUG, sprintf("ZarafaBackend->SendMail(): convert html forwarded message charset (only fw set) from '%s' to '65001'", $cpid[$sendMailProps["internetcpid"]]));
                     $fwbodyHtml = Utils::ConvertCodepageStringToUtf8($cpid[$sendMailProps["internetcpid"]], $fwbodyHtml);
                 } else {
                     ZLog::Write(LOGLEVEL_DEBUG, "ZarafaBackend->SendMail(): no charset conversion done for html forwarded message");
                     $fwbodyHtml = w2u($fwbodyHtml);
                 }
                 $mapiprops[$sendMailProps["html"]] = $bodyHtml . "<br><br>" . $fwbodyHtml;
             }
         }
     }
     mapi_setprops($mapimessage, $mapiprops);
     mapi_message_savechanges($mapimessage);
     mapi_message_submitmessage($mapimessage);
     $hr = mapi_last_hresult();
     if ($hr) {
         throw new StatusException(sprintf("ZarafaBackend->SendMail(): Error saving/submitting the message to the Outbox: 0x%X", mapi_last_hresult()), SYNC_COMMONSTATUS_MAILSUBMISSIONFAILED);
     }
     ZLog::Write(LOGLEVEL_DEBUG, "ZarafaBackend->SendMail(): email submitted");
     return true;
 }
開發者ID:inkoss,項目名稱:karoshi-server,代碼行數:101,代碼來源:zarafa.php

示例10: SendMail

 function SendMail($rfc822, $forward = false, $reply = false, $parent = false)
 {
     if (WBXML_DEBUG == true) {
         debugLog("SendMail: forward: {$forward}   reply: {$reply}   parent: {$parent}\n" . $rfc822);
     }
     // Open the outbox and create the message there
     $storeprops = mapi_getprops($this->_defaultstore, array(PR_IPM_OUTBOX_ENTRYID, PR_IPM_SENTMAIL_ENTRYID));
     if (!isset($storeprops[PR_IPM_OUTBOX_ENTRYID])) {
         debugLog("Outbox not found to create message");
         return false;
     }
     $outbox = mapi_msgstore_openentry($this->_defaultstore, $storeprops[PR_IPM_OUTBOX_ENTRYID]);
     if (!$outbox) {
         debugLog("Unable to open outbox");
         return false;
     }
     $mapimessage = mapi_folder_createmessage($outbox);
     //message properties to be set
     $mapiprops = array();
     // only save the outgoing in sent items folder if the mobile requests it
     if (isset($storeprops[PR_IPM_SENTMAIL_ENTRYID])) {
         $mapiprops[PR_SENTMAIL_ENTRYID] = $storeprops[PR_IPM_SENTMAIL_ENTRYID];
     } else {
         debugLog("PR_SENTMAIL_ENTRYID is not set. The sent message will not be moved to Sent Items.");
     }
     if ($forward) {
         $orig = $forward;
     }
     if ($reply) {
         $orig = $reply;
     }
     // Check if imtomapi function is available and use it to send the mime message.
     // It is available since ZCP 7.0.6
     // @see http://jira.zarafa.com/browse/ZCP-9508
     if (function_exists('mapi_feature') && mapi_feature('INETMAPI_IMTOMAPI')) {
         debugLog("Use the mapi_inetmapi_imtomapi function");
         $ab = mapi_openaddressbook($this->_session);
         mapi_inetmapi_imtomapi($this->_session, $this->_defaultstore, $ab, $mapimessage, $rfc822, array());
         // Delete the PR_SENT_REPRESENTING_* properties because some android devices
         // do not send neither From nor Sender header causing empty PR_SENT_REPRESENTING_NAME and
         // PR_SENT_REPRESENTING_EMAIL_ADDRESS properties and "broken" PR_SENT_REPRESENTING_ENTRYID
         // which results in spooler not being able to send the message.
         // @see http://jira.zarafa.com/browse/ZP-85
         mapi_deleteprops($mapimessage, array(PR_SENT_REPRESENTING_NAME, PR_SENT_REPRESENTING_EMAIL_ADDRESS, PR_SENT_REPRESENTING_ENTRYID, PR_SENT_REPRESENTING_ADDRTYPE, PR_SENT_REPRESENTING_SEARCH_KEY));
         if (isset($orig) && $orig) {
             $entryid = mapi_msgstore_entryidfromsourcekey($this->_defaultstore, hex2bin($parent), hex2bin($orig));
             $fwmessage = mapi_msgstore_openentry($this->_defaultstore, $entryid);
             if ($fwmessage) {
                 //update icon when forwarding or replying message
                 if ($forward) {
                     mapi_setprops($fwmessage, array(PR_ICON_INDEX => 262));
                 } elseif ($reply) {
                     mapi_setprops($fwmessage, array(PR_ICON_INDEX => 261));
                 }
                 mapi_savechanges($fwmessage);
                 if ($forward) {
                     $this->_copyAttachments($mapimessage, $fwmessage);
                 }
                 $body = $this->_readPropStream($mapimessage, PR_BODY);
                 $body_html = $this->_readPropStream($mapimessage, PR_HTML);
                 if (strlen($body) > 0) {
                     $fwbody = $this->_readPropStream($fwmessage, PR_BODY);
                     $body .= $fwbody;
                 }
                 if (strlen($body_html) > 0) {
                     $fwbody_html = $this->_readPropStream($fwmessage, PR_HTML);
                     $body_html .= $fwbody_html;
                 }
                 mapi_setprops($mapimessage, array(PR_BODY => $body));
                 if (strlen($body_html) > 0) {
                     mapi_setprops($mapimessage, array(PR_HTML => $body_html));
                 }
             }
         }
         if (!empty($mapiprops)) {
             mapi_setprops($mapimessage, $mapiprops);
         }
         mapi_message_savechanges($mapimessage);
         mapi_message_submitmessage($mapimessage);
         $hr = mapi_last_hresult();
         if ($hr) {
             debugLog(sprintf("SendMail(): Error saving/submitting the message to the Outbox: 0x%X", mapi_last_hresult()));
             return false;
         }
         return true;
     }
     $mimeParams = array('decode_headers' => true, 'decode_bodies' => true, 'include_bodies' => true, 'charset' => 'utf-8');
     $mimeObject = new Mail_mimeDecode($rfc822);
     $message = $mimeObject->decode($mimeParams);
     mapi_setprops($mapimessage, array(PR_SUBJECT => u2wi(isset($message->headers["subject"]) ? $message->headers["subject"] : ""), PR_SENTMAIL_ENTRYID => $storeprops[PR_IPM_SENTMAIL_ENTRYID], PR_MESSAGE_CLASS => "IPM.Note", PR_MESSAGE_DELIVERY_TIME => time()));
     if (isset($message->headers["x-priority"])) {
         switch ($message->headers["x-priority"]) {
             case 1:
             case 2:
                 $priority = PRIO_URGENT;
                 $importance = IMPORTANCE_HIGH;
                 break;
             case 4:
             case 5:
                 $priority = PRIO_NONURGENT;
//.........這裏部分代碼省略.........
開發者ID:BackupTheBerlios,項目名稱:z-push-svn,代碼行數:101,代碼來源:ics.php

示例11: SendMail


//.........這裏部分代碼省略.........
         $mr = new Meetingrequest($this->defaultstore, $mapimessage);
         $appointments = $mr->findCalendarItems($props[$meetingRequestProps["goidtag"]]);
         if (is_array($appointments) && !empty($appointments)) {
             $app = mapi_msgstore_openentry($this->defaultstore, $appointments[0]);
             $appprops = mapi_getprops($app, array($meetingRequestProps["appSeqNr"]));
             if (isset($appprops[$meetingRequestProps["appSeqNr"]]) && $appprops[$meetingRequestProps["appSeqNr"]]) {
                 $mapiprops[$meetingRequestProps["appSeqNr"]] = $appprops[$meetingRequestProps["appSeqNr"]];
                 ZLog::Write(LOGLEVEL_DEBUG, sprintf("Set sequence number to:%d", $appprops[$meetingRequestProps["appSeqNr"]]));
             }
         }
     }
     // Delete the PR_SENT_REPRESENTING_* properties because some android devices
     // do not send neither From nor Sender header causing empty PR_SENT_REPRESENTING_NAME and
     // PR_SENT_REPRESENTING_EMAIL_ADDRESS properties and "broken" PR_SENT_REPRESENTING_ENTRYID
     // which results in spooler not being able to send the message.
     // @see http://jira.zarafa.com/browse/ZP-85
     // If using KOE send-as feature, we keep this properties because they actually are the send-as
     if (!$sendingAsSomeone) {
         mapi_deleteprops($mapimessage, array($sendMailProps["sentrepresentingname"], $sendMailProps["sentrepresentingemail"], $sendMailProps["representingentryid"], $sendMailProps["sentrepresentingaddt"], $sendMailProps["sentrepresentinsrchk"]));
     }
     if (isset($sm->source->itemid) && $sm->source->itemid) {
         // answering an email in a public/shared folder
         // TODO as the store is setup, we should actually user $this->store instead of $this->defaultstore - nevertheless we need to make sure this store is able to send mail (has an outbox)
         if (!$this->Setup(ZPush::GetAdditionalSyncFolderStore($sm->source->folderid))) {
             throw new StatusException(sprintf("KopanoBackend->SendMail() could not Setup() the backend for folder id '%s'", $sm->source->folderid), SYNC_COMMONSTATUS_SERVERERROR);
         }
         $entryid = mapi_msgstore_entryidfromsourcekey($this->store, hex2bin($sm->source->folderid), hex2bin($sm->source->itemid));
         if ($entryid) {
             $fwmessage = mapi_msgstore_openentry($this->store, $entryid);
         }
         if (isset($fwmessage) && $fwmessage) {
             // update icon and last_verb when forwarding or replying message
             // reply-all (verb 103) is not supported, as we cannot really detect this case
             if ($sm->forwardflag) {
                 $updateProps = array(PR_ICON_INDEX => 262, PR_LAST_VERB_EXECUTED => 104);
             } elseif ($sm->replyflag) {
                 $updateProps = array(PR_ICON_INDEX => 261, PR_LAST_VERB_EXECUTED => 102);
             }
             if (isset($updateProps)) {
                 $updateProps[PR_LAST_VERB_EXECUTION_TIME] = time();
                 mapi_setprops($fwmessage, $updateProps);
                 mapi_savechanges($fwmessage);
             }
             // only attach the original message if the mobile does not send it itself
             if (!isset($sm->replacemime)) {
                 // get message's body in order to append forward or reply text
                 if (!isset($body)) {
                     $body = MAPIUtils::readPropStream($mapimessage, PR_BODY);
                 }
                 if (!isset($bodyHtml)) {
                     $bodyHtml = MAPIUtils::readPropStream($mapimessage, PR_HTML);
                 }
                 $cpid = mapi_getprops($fwmessage, array($sendMailProps["internetcpid"]));
                 if ($sm->forwardflag) {
                     // attach the original attachments to the outgoing message
                     $this->copyAttachments($mapimessage, $fwmessage);
                 }
                 // regarding the conversion @see ZP-470
                 if (strlen($body) > 0) {
                     $fwbody = MAPIUtils::readPropStream($fwmessage, PR_BODY);
                     // if only the old message's cpid is set, convert from old charset to utf-8
                     if (isset($cpid[$sendMailProps["internetcpid"]]) && $cpid[$sendMailProps["internetcpid"]] != INTERNET_CPID_UTF8) {
                         ZLog::Write(LOGLEVEL_DEBUG, sprintf("KopanoBackend->SendMail(): convert plain forwarded message charset (only fw set) from '%s' to '65001'", $cpid[$sendMailProps["internetcpid"]]));
                         $fwbody = Utils::ConvertCodepageStringToUtf8($cpid[$sendMailProps["internetcpid"]], $fwbody);
                     } else {
                         ZLog::Write(LOGLEVEL_DEBUG, "KopanoBackend->SendMail(): no charset conversion done for plain forwarded message");
                         $fwbody = w2u($fwbody);
                     }
                     $mapiprops[$sendMailProps["body"]] = $body . "\r\n\r\n" . $fwbody;
                 }
                 if (strlen($bodyHtml) > 0) {
                     $fwbodyHtml = MAPIUtils::readPropStream($fwmessage, PR_HTML);
                     // if only new message's cpid is set, convert to UTF-8
                     if (isset($cpid[$sendMailProps["internetcpid"]]) && $cpid[$sendMailProps["internetcpid"]] != INTERNET_CPID_UTF8) {
                         ZLog::Write(LOGLEVEL_DEBUG, sprintf("KopanoBackend->SendMail(): convert html forwarded message charset (only fw set) from '%s' to '65001'", $cpid[$sendMailProps["internetcpid"]]));
                         $fwbodyHtml = Utils::ConvertCodepageStringToUtf8($cpid[$sendMailProps["internetcpid"]], $fwbodyHtml);
                     } else {
                         ZLog::Write(LOGLEVEL_DEBUG, "KopanoBackend->SendMail(): no charset conversion done for html forwarded message");
                         $fwbodyHtml = w2u($fwbodyHtml);
                     }
                     $mapiprops[$sendMailProps["html"]] = $bodyHtml . "<br><br>" . $fwbodyHtml;
                 }
             }
         } else {
             // no fwmessage could be opened and we need it because we do not replace mime
             if (!isset($sm->replacemime) || $sm->replacemime == false) {
                 throw new StatusException(sprintf("KopanoBackend->SendMail(): Could not open message id '%s' in folder id '%s' to be replied/forwarded: 0x%X", $sm->source->itemid, $sm->source->folderid, mapi_last_hresult()), SYNC_COMMONSTATUS_ITEMNOTFOUND);
             }
         }
     }
     mapi_setprops($mapimessage, $mapiprops);
     mapi_message_savechanges($mapimessage);
     mapi_message_submitmessage($mapimessage);
     $hr = mapi_last_hresult();
     if ($hr) {
         throw new StatusException(sprintf("KopanoBackend->SendMail(): Error saving/submitting the message to the Outbox: 0x%X", mapi_last_hresult()), SYNC_COMMONSTATUS_MAILSUBMISSIONFAILED);
     }
     ZLog::Write(LOGLEVEL_DEBUG, "KopanoBackend->SendMail(): email submitted");
     return true;
 }
開發者ID:EGroupware,項目名稱:z-push,代碼行數:101,代碼來源:kopano.php


注:本文中的mapi_message_savechanges函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。