4 * Deliver_IMAP.class.php
6 * Delivery backend for the Deliver class.
8 * @copyright 1999-2021 The SquirrelMail Project Team
9 * @license http://opensource.org/licenses/gpl-license.php GNU Public License
11 * @package squirrelmail
14 /** This of course depends upon Deliver.. */
16 require_once(SM_PATH
. 'class/deliver/Deliver.class.php');
19 * This class is incomplete and entirely undocumented.
20 * @package squirrelmail
22 class Deliver_IMAP
extends Deliver
{
29 * function send_mail - send the message parts to the IMAP stream
31 * Overridden from parent class so that we can insert some
32 * IMAP APPEND commands before and after the message is
33 * sent on the IMAP stream.
35 * @param Message $message Message object to send
36 * @param string $header Headers ready to send
37 * @param string $boundary Message parts boundary
38 * @param resource $stream Handle to the SMTP stream
39 * (when FALSE, nothing will be
40 * written to the stream; this can
41 * be used to determine the actual
42 * number of bytes that will be
43 * written to the stream)
44 * @param int &$raw_length The number of bytes written (or that
45 * would have been written) to the
46 * output stream - NOTE that this is
48 * @param string $folder The IMAP folder to which the
49 * message is being sent
54 function send_mail($message, $header, $boundary, $stream=false,
55 &$raw_length, $folder=NULL) {
58 die('Internal error. Cannot pass NULL folder name to Deliver_IMAP::send_mail()');
60 // write the body without providing a stream so we
61 // can calculate the final length - after this call,
62 // $final_length will be our correct final length value
64 $final_length = $raw_length;
65 $this->writeBody($message, 0, $final_length, $boundary);
68 // now if we have a real live stream, send the message
71 sqimap_append ($stream, $folder, $final_length);
73 $this->preWriteToStream($header);
74 $this->writeToStream($stream, $header);
75 $this->writeBody($message, $stream, $raw_length, $boundary);
77 sqimap_append_done ($stream, $folder);
83 /* to do: finishing the imap-class so the initStream function can call the