2011-07-01 12:37:47 +02:00
< ? php
/*************************************************************************** \
* eGroupWare - FeLaMiMail *
* http :// www . linux - at - work . de *
* http :// www . phpgw . de *
* http :// www . egroupware . org *
* Written by : Lars Kneschke [ lkneschke @ linux - at - work . de ] *
* ------------------------------------------------- *
* This program is free software ; you can redistribute it and / or modify it *
* under the terms of the GNU General Public License as published by the *
* Free Software Foundation ; version 2 of the License . *
\ ***************************************************************************/
/* $Id$ */
class uicompose
{
var $public_functions = array
(
'action' => True ,
'compose' => True ,
'composeFromDraft' => True ,
'getAttachment' => True ,
'fileSelector' => True ,
'forward' => True ,
'composeAsNew' => True ,
'composeAsForward' => True ,
'reply' => True ,
'replyAll' => True ,
'selectFolder' => True ,
);
var $destinations = array (
'to' => 'to' ,
'cc' => 'cc' ,
'bcc' => 'bcc' ,
'replyto' => 'replyto' ,
'folder' => 'folder'
);
/**
* Instance of bofelamimail
*
* @ var bofelamimail
*/
var $bofelamimail ;
/**
* Instance of bocompose
*
* @ var bocompose
*/
var $bocompose ;
/**
* Active preferences , reference to $this -> bofelamimail -> mailPreferences
*
* @ var array
*/
var $mailPreferences ;
/**
* Instance of Template class
*
* @ var Template
*/
var $t ;
function uicompose ()
{
$this -> displayCharset = $GLOBALS [ 'egw' ] -> translation -> charset ();
if ( ! isset ( $_POST [ 'composeid' ]) && ! isset ( $_GET [ 'composeid' ]))
{
// create new compose session
$this -> bocompose = CreateObject ( 'felamimail.bocompose' , '' , $this -> displayCharset );
$this -> composeID = $this -> bocompose -> getComposeID ();
}
else
{
// reuse existing compose session
if ( isset ( $_POST [ 'composeid' ]))
$this -> composeID = $_POST [ 'composeid' ];
else
$this -> composeID = $_GET [ 'composeid' ];
$this -> bocompose = CreateObject ( 'felamimail.bocompose' , $this -> composeID , $this -> displayCharset );
}
$this -> t = CreateObject ( 'phpgwapi.Template' , EGW_APP_TPL );
$this -> bofelamimail =& $this -> bocompose -> bofelamimail ;
$this -> mailPreferences =& $this -> bofelamimail -> mailPreferences ;
$this -> t -> set_unknowns ( 'remove' );
$this -> rowColor [ 0 ] = $GLOBALS [ 'egw_info' ][ " theme " ][ " bg01 " ];
$this -> rowColor [ 1 ] = $GLOBALS [ 'egw_info' ][ " theme " ][ " bg02 " ];
}
function unhtmlentities ( $string )
{
$trans_tbl = get_html_translation_table ( HTML_ENTITIES );
$trans_tbl = array_flip ( $trans_tbl );
return strtr ( $string , $trans_tbl );
}
function action ()
{
$formData [ 'identity' ] = ( int ) $_POST [ 'identity' ];
2011-07-19 13:42:35 +02:00
foreach (( array ) $_POST [ 'destination' ] as $key => $destination ) {
2011-07-01 12:37:47 +02:00
if ( ! empty ( $_POST [ 'address' ][ $key ])) {
if ( $destination == 'folder' ) {
$formData [ $destination ][] = $GLOBALS [ 'egw' ] -> translation -> convert ( $_POST [ 'address' ][ $key ], $this -> charset , 'UTF7-IMAP' );
} else {
$formData [ $destination ][] = $_POST [ 'address' ][ $key ];
}
}
}
$formData [ 'subject' ] = $this -> bocompose -> stripSlashes ( $_POST [ 'subject' ]);
$formData [ 'body' ] = $this -> bocompose -> stripSlashes ( $_POST [ 'body' ]);
// if the body is empty, maybe someone pasted something with scripts, into the message body
if ( empty ( $formData [ 'body' ]))
{
// this is to be found with the egw_unset_vars array for the _POST['body'] array
$name = '_POST' ;
$key = 'body' ;
#error_log($GLOBALS['egw_unset_vars'][$name.'['.$key.']']);
if ( isset ( $GLOBALS [ 'egw_unset_vars' ][ $name . '[' . $key . ']' ]))
{
$formData [ 'body' ] = bocompose :: _getCleanHTML ( $GLOBALS [ 'egw_unset_vars' ][ $name . '[' . $key . ']' ]);
}
}
$formData [ 'priority' ] = $this -> bocompose -> stripSlashes ( $_POST [ 'priority' ]);
$formData [ 'signatureID' ] = ( int ) $_POST [ 'signatureID' ];
$formData [ 'stationeryID' ] = $_POST [ 'stationeryID' ];
$formData [ 'mimeType' ] = $this -> bocompose -> stripSlashes ( $_POST [ 'mimeType' ]);
2011-10-31 11:59:31 +01:00
if ( $formData [ 'mimeType' ] == 'html' && html :: htmlarea_availible () === false )
{
$formData [ 'mimeType' ] = 'plain' ;
$formData [ 'body' ] = $this -> bocompose -> convertHTMLToText ( $formData [ 'body' ]);
}
2011-07-01 12:37:47 +02:00
$formData [ 'disposition' ] = ( bool ) $_POST [ 'disposition' ];
$formData [ 'to_infolog' ] = $_POST [ 'to_infolog' ];
$formData [ 'to_tracker' ] = $_POST [ 'to_tracker' ];
//$formData['mailbox'] = $_GET['mailbox'];
if (( bool ) $_POST [ 'printit' ] == true ) {
$formData [ 'printit' ] = 1 ;
$formData [ 'isDraft' ] = 1 ;
// pint the composed message. therefore save it as draft and reopen it as plain printwindow
$formData [ 'subject' ] = " [ " . lang ( 'printview' ) . " :] " . $formData [ 'subject' ];
2011-10-17 17:36:34 +02:00
$messageUid = $this -> bocompose -> saveAsDraft ( $formData , $destinationFolder );
2011-07-01 12:37:47 +02:00
if ( ! $messageUid ) {
print " <script type= \" text/javascript \" >alert(' " . lang ( " Error: Could not save Message as Draft " ) . " ');</script> " ;
return ;
}
$uidisplay = CreateObject ( 'felamimail.uidisplay' );
2011-10-17 17:36:34 +02:00
$uidisplay -> printMessage ( $messageUid , $formData [ 'printit' ], $destinationFolder );
2011-07-01 12:37:47 +02:00
//egw::link('/index.php',array('menuaction' => 'felamimail.uidisplay.printMessage','uid'=>$messageUid));
return ;
}
if (( bool ) $_POST [ 'saveAsDraft' ] == true ) {
$formData [ 'isDraft' ] = 1 ;
// save as draft
2013-01-29 15:38:36 +01:00
$folder = $this -> bofelamimail -> getDraftFolder ();
2011-07-01 12:37:47 +02:00
$this -> bofelamimail -> reopen ( $folder );
$status = $this -> bofelamimail -> getFolderStatus ( $folder );
2011-07-19 13:39:56 +02:00
//error_log(__METHOD__.__LINE__.array2string(array('Folder'=>$folder,'Status'=>$status)));
2011-07-01 12:37:47 +02:00
$uidNext = $status [ 'uidnext' ]; // we may need that, if the server does not return messageUIDs of saved/appended messages
2011-07-19 13:39:56 +02:00
$messageUid = $this -> bocompose -> saveAsDraft ( $formData , $folder ); // folder may change
2011-07-01 12:37:47 +02:00
if ( ! $messageUid ) {
print " <script type= \" text/javascript \" >alert(' " . lang ( " Error: Could not save Message as Draft " ) . " " . lang ( " Trying to recover from session data " ) . " ');</script> " ;
//try to reopen the mail from session data
$this -> compose ( 'to' , true );
return ;
}
// saving as draft, does not mean closing the message
unset ( $_POST [ 'composeid' ]);
unset ( $_GET [ 'composeid' ]);
$uicompose = CreateObject ( 'felamimail.uicompose' );
$messageUid = ( $messageUid === true ? $uidNext : $messageUid );
2011-07-19 14:56:45 +02:00
if ( ! $uicompose -> bofelamimail -> icServer -> _connected ) $uicompose -> bofelamimail -> openConnection ( $uicompose -> bofelamimail -> profileID );
2011-07-21 13:13:37 +02:00
if ( $uicompose -> bofelamimail -> getMessageHeader ( $messageUid ))
2011-07-01 12:37:47 +02:00
{
//error_log(__METHOD__.__LINE__.' (re)open drafted message with new UID: '.$messageUid.' in folder:'.$folder);
$uicompose -> bocompose -> getDraftData ( $uicompose -> bofelamimail -> icServer , $folder , $messageUid );
$uicompose -> compose ( 'to' , true );
return ;
}
} else {
2013-01-24 13:59:08 +01:00
$cachedComposeID = egw_cache :: getCache ( egw_cache :: SESSION , 'email' , 'composeIdCache' . trim ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'account_id' ]), $callback = null , $callback_params = array (), $expiration = 60 );
egw_cache :: setCache ( egw_cache :: SESSION , 'email' , 'composeIdCache' . trim ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'account_id' ]), $this -> composeID , $expiration = 60 );
2012-11-08 17:09:58 +01:00
//error_log(__METHOD__.__LINE__.' '.$formData['subject'].' '.$cachedComposeID.'<->'.$this->composeID);
2013-01-24 16:56:47 +01:00
if ( ! empty ( $cachedComposeID ) && $cachedComposeID == $this -> composeID )
{
//already send
print " <script type= \" text/javascript \" >window.close();</script> " ;
return ;
}
2011-07-01 12:37:47 +02:00
if ( ! $this -> bocompose -> send ( $formData )) {
2013-01-23 09:34:22 +01:00
// reset the cached composeID, as something failed
2013-01-24 13:59:08 +01:00
egw_cache :: setCache ( egw_cache :: SESSION , 'email' , 'composeIdCache' . trim ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'account_id' ]), null , $expiration = 60 );
2011-07-01 12:37:47 +02:00
// print "<script type=\"text/javascript\">alert('".lang("Error: Could not send Message.")." ".lang("Trying to recover from session data")."');</script>";
$this -> compose ();
return ;
}
}
#common::egw_exit();
print " <script type= \" text/javascript \" >window.close();</script> " ;
}
function composeAsForward ( $_focusElement = 'to' )
{
if ( isset ( $_GET [ 'forwardmails' ]))
{
unset ( $_GET [ 'forwardmails' ]);
$replyID = $_GET [ 'reply_id' ];
$replyIds = explode ( ',' , $replyID );
$icServer = $this -> bofelamimail -> profileID ;
2012-11-05 09:58:03 +01:00
$folder = ( isset ( $_GET [ 'folder' ]) ? base64_decode ( $_GET [ 'folder' ]) : base64_decode ( $_GET [ 'mailbox' ]));
2011-07-01 12:37:47 +02:00
//_debug_array(array('reply_id'=>$replyIds,'folder'=>$folder));
if ( ! empty ( $folder ) && ! empty ( $replyID ) ) {
// this fill the session data with the values from the original email
$buff = $this -> bocompose -> preferencesArray [ 'message_forwarding' ];
$this -> bocompose -> preferencesArray [ 'message_forwarding' ] = 'asmail' ;
foreach ( $replyIds as $key => $id )
{
$this -> bocompose -> getForwardData ( $icServer , $folder , $id , NULL );
}
$this -> bocompose -> preferencesArray [ 'message_forwarding' ] = $buff ;
}
}
$this -> compose ( $_focusElement );
}
2012-10-31 15:35:13 +01:00
/**
* function compose
* this function is used to fill the compose dialog with the content provided by session data
*
* @ var _focusElement varchar subject , to , body supported
* @ var suppressSigOnTop boolean
* @ var isReply boolean
*/
2012-01-16 17:43:33 +01:00
function compose ( $_focusElement = 'to' , $suppressSigOnTop = false , $isReply = false )
2011-07-01 12:37:47 +02:00
{
2012-11-29 17:18:40 +01:00
//error_log(__METHOD__.__LINE__.array2string($_REQUEST));
2013-01-17 12:22:24 +01:00
if ( isset ( $_GET [ 'reply_id' ])) $replyID = $_GET [ 'reply_id' ];
2011-07-01 12:37:47 +02:00
// read the data from session
// all values are empty for a new compose window
2012-11-29 17:18:40 +01:00
$insertSigOnTop = false ;
2011-07-01 12:37:47 +02:00
$sessionData = $this -> bocompose -> getSessionData ();
2011-12-12 18:24:52 +01:00
$alwaysAttachVCardAtCompose = false ; // we use this to eliminate double attachments, if users VCard is already present/attached
2011-12-16 12:26:01 +01:00
if ( isset ( $GLOBALS [ 'egw_info' ][ 'apps' ][ 'stylite' ]) && ( isset ( $this -> bocompose -> preferencesArray [ 'attachVCardAtCompose' ]) &&
2011-12-12 18:24:52 +01:00
$this -> bocompose -> preferencesArray [ 'attachVCardAtCompose' ]))
{
$alwaysAttachVCardAtCompose = true ;
2011-12-21 15:13:36 +01:00
if ( ! is_array ( $_REQUEST [ 'preset' ][ 'file' ]) && ! empty ( $_REQUEST [ 'preset' ][ 'file' ]))
{
$f = $_REQUEST [ 'preset' ][ 'file' ];
$_REQUEST [ 'preset' ][ 'file' ] = array ( $f );
}
2011-12-12 18:24:52 +01:00
$_REQUEST [ 'preset' ][ 'file' ][] = " vfs://default/apps/addressbook/ " . $GLOBALS [ 'egw' ] -> accounts -> id2name ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'account_id' ], 'person_id' ) . " /.entry " ;
}
2013-03-21 11:33:40 +01:00
// an app passed the request for fetching and mailing an entry
if ( isset ( $_REQUEST [ 'app' ]) && isset ( $_REQUEST [ 'method' ]) && isset ( $_REQUEST [ 'id' ]))
{
$app = $_REQUEST [ 'app' ];
$mt = $_REQUEST [ 'method' ];
$id = $_REQUEST [ 'id' ];
// passed method MUST be registered
$method = egw_link :: get_registry ( $app , $mt );
//error_log(__METHOD__.__LINE__.array2string($method));
if ( $method )
{
$res = ExecMethod ( $method , array ( $id , 'html' ));
//_debug_array($res);
if ( ! empty ( $res ))
{
$insertSigOnTop = 'below' ;
if ( isset ( $res [ 'attachments' ]) && is_array ( $res [ 'attachments' ]))
{
foreach ( $res [ 'attachments' ] as $f )
{
$_REQUEST [ 'preset' ][ 'file' ][] = $f ;
}
}
$sessionData [ 'subject' ] = lang ( $app ) . ' #' . $res [ 'id' ] . ': ' ;
foreach ( array ( 'subject' , 'body' , 'mimetype' ) as $name ) {
$sName = $name ;
if ( $name == 'mimetype' )
{
$sName = 'mimeType' ;
$sessionData [ $sName ] = $res [ $name ];
}
else
{
if ( $res [ $name ]) $sessionData [ $sName ] .= ( strlen ( $sessionData [ $sName ]) > 0 ? ' ' : '' ) . $res [ $name ];
}
}
}
}
}
// handle preset info/values
2011-07-01 12:37:47 +02:00
if ( is_array ( $_REQUEST [ 'preset' ]))
{
//_debug_array($_REQUEST);
if ( $_REQUEST [ 'preset' ][ 'mailto' ]) {
// handle mailto strings such as
// mailto:larry,dan?cc=mike&bcc=sue&subject=test&body=type+your&body=message+here
// the above string may be htmlentyty encoded, then multiple body tags are supported
// first, strip the mailto: string out of the mailto URL
2012-11-20 17:17:33 +01:00
$tmp_send_to = ( stripos ( $_REQUEST [ 'preset' ][ 'mailto' ], 'mailto' ) === false ? $_REQUEST [ 'preset' ][ 'mailto' ] : trim ( substr ( html_entity_decode ( $_REQUEST [ 'preset' ][ 'mailto' ]), 7 )));
2011-07-01 12:37:47 +02:00
// check if there is more than the to address
$mailtoArray = explode ( '?' , $tmp_send_to , 2 );
if ( $mailtoArray [ 1 ]) {
// check if there are more than one requests
$addRequests = explode ( '&' , $mailtoArray [ 1 ]);
foreach ( $addRequests as $key => $reqval ) {
// the additional requests should have a =, to separate key from value.
$keyValuePair = explode ( '=' , $reqval , 2 );
$sessionData [ $keyValuePair [ 0 ]] .= ( strlen ( $sessionData [ $keyValuePair [ 0 ]]) > 0 ? ' ' : '' ) . $keyValuePair [ 1 ];
}
}
$sessionData [ 'to' ] = $mailtoArray [ 0 ];
// if the mailto string is not htmlentity decoded the arguments are passed as simple requests
foreach ( array ( 'cc' , 'bcc' , 'subject' , 'body' ) as $name ) {
if ( $_REQUEST [ $name ]) $sessionData [ $name ] .= ( strlen ( $sessionData [ $name ]) > 0 ? ( $name == 'cc' || $name == 'bcc' ? ',' : ' ' ) : '' ) . $_REQUEST [ $name ];
}
}
if ( isset ( $_REQUEST [ 'preset' ][ 'file' ]))
{
$names = ( array ) $_REQUEST [ 'preset' ][ 'name' ];
$types = ( array ) $_REQUEST [ 'preset' ][ 'type' ];
2012-11-29 17:18:40 +01:00
//if (!empty($types) && in_array('text/calendar; method=request',$types))
2011-12-12 18:24:52 +01:00
$files = ( array ) $_REQUEST [ 'preset' ][ 'file' ];
foreach ( $files as $k => $path )
2011-07-01 12:37:47 +02:00
{
2012-11-30 13:35:25 +01:00
if ( ! empty ( $types [ $k ]) && stripos ( $types [ $k ], 'text/calendar' ) !== false )
{
$insertSigOnTop = 'below' ;
}
2013-03-21 11:33:40 +01:00
//error_log(__METHOD__.__LINE__.$path.'->'.array2string(parse_url($path,PHP_URL_SCHEME == 'vfs')));
2011-07-01 12:37:47 +02:00
if ( parse_url ( $path , PHP_URL_SCHEME == 'vfs' ))
{
2011-11-29 13:09:29 +01:00
$type = egw_vfs :: mime_content_type ( $path );
// special handling for attaching vCard of iCal --> use their link-title as name
if ( substr ( $path , - 7 ) != '/.entry' ||
! ( list ( $app , $id ) = array_slice ( explode ( '/' , $path ), - 3 )) ||
! ( $name = egw_link :: title ( $app , $id )))
{
$name = urldecode ( egw_vfs :: basename ( $path ));
}
else
{
$name .= '.' . mime_magic :: mime2ext ( $type );
}
2011-07-01 12:37:47 +02:00
$formData = array (
2011-11-29 13:09:29 +01:00
'name' => $name ,
'type' => $type ,
2013-03-21 15:26:53 +01:00
'file' => urldecode ( $path ),
2013-03-21 13:46:41 +01:00
'size' => filesize ( urldecode ( $path )),
2011-07-01 12:37:47 +02:00
);
if ( $formData [ 'type' ] == egw_vfs :: DIR_MIME_TYPE ) continue ; // ignore directories
}
elseif ( is_readable ( $path ))
{
$formData = array (
'name' => isset ( $names [ $k ]) ? $names [ $k ] : basename ( $path ),
'type' => isset ( $types [ $k ]) ? $types [ $k ] : ( function_exists ( 'mime_content_type' ) ? mime_content_type ( $path ) : mime_magic :: filename2mime ( $path )),
'file' => $path ,
'size' => filesize ( $path ),
);
}
else
{
continue ;
}
2011-12-12 18:24:52 +01:00
$this -> bocompose -> addAttachment ( $formData ,( $alwaysAttachVCardAtCompose ? true : false ));
2011-07-01 12:37:47 +02:00
}
2012-11-20 17:17:33 +01:00
$remember = array ();
2013-03-21 11:33:40 +01:00
if ( isset ( $_REQUEST [ 'preset' ][ 'mailto' ]) || ( isset ( $_REQUEST [ 'app' ]) && isset ( $_REQUEST [ 'method' ]) && isset ( $_REQUEST [ 'id' ])))
2012-11-20 17:17:33 +01:00
{
foreach ( array_keys ( $sessionData ) as $k )
{
2013-03-21 11:33:40 +01:00
if ( in_array ( $k , array ( 'to' , 'cc' , 'bcc' , 'subject' , 'body' , 'mimeType' ))) $remember [ $k ] = $sessionData [ $k ];
2012-11-20 17:17:33 +01:00
}
}
2011-07-01 12:37:47 +02:00
$sessionData = $this -> bocompose -> getSessionData ();
2013-03-21 11:33:40 +01:00
if ( ! empty ( $remember )) $sessionData = array_merge ( $sessionData , $remember );
2011-07-01 12:37:47 +02:00
}
foreach ( array ( 'to' , 'cc' , 'bcc' , 'subject' , 'body' ) as $name )
{
if ( $_REQUEST [ 'preset' ][ $name ]) $sessionData [ $name ] = $_REQUEST [ 'preset' ][ $name ];
}
}
2013-03-21 11:33:40 +01:00
//_debug_array($sessionData);
2011-07-01 12:37:47 +02:00
// is the to address set already?
if ( ! empty ( $_REQUEST [ 'send_to' ]))
{
$sessionData [ 'to' ] = base64_decode ( $_REQUEST [ 'send_to' ]);
2012-10-31 15:35:13 +01:00
// first check if there is a questionmark or ampersand
if ( strpos ( $sessionData [ 'to' ], '?' ) !== false ) list ( $sessionData [ 'to' ], $rest ) = explode ( '?' , $sessionData [ 'to' ], 2 );
2013-01-18 09:20:35 +01:00
$sessionData [ 'to' ] = html_entity_decode ( $sessionData [ 'to' ]);
2012-10-31 15:35:13 +01:00
if (( $at_pos = strpos ( $sessionData [ 'to' ], '@' )) !== false )
{
if (( $amp_pos = strpos ( substr ( $sessionData [ 'to' ], $at_pos ), '&' )) !== false )
{
//list($email,$addoptions) = explode('&',$value,2);
$email = substr ( $sessionData [ 'to' ], 0 , $amp_pos + $at_pos );
$rest = substr ( $sessionData [ 'to' ], $amp_pos + $at_pos + 1 );
//error_log(__METHOD__.__LINE__.$email.' '.$rest);
$sessionData [ 'to' ] = $email ;
}
}
if ( strpos ( $sessionData [ 'to' ], '%40' ) !== false ) $sessionData [ 'to' ] = html :: purify ( str_replace ( '%40' , '@' , $sessionData [ 'to' ]));
$rarr = array ( html :: purify ( $rest ));
if ( isset ( $rest ) &&! empty ( $rest ) && strpos ( $rest , '&' ) !== false ) $rarr = explode ( '&' , $rest );
//error_log(__METHOD__.__LINE__.$sessionData['to'].'->'.array2string($rarr));
$karr = array ();
foreach ( $rarr as $ri => $rval )
{
//must contain =
if ( strpos ( $rval , '=' ) !== false )
{
$k = $v = '' ;
list ( $k , $v ) = explode ( '=' , $rval , 2 );
$karr [ $k ] = $v ;
}
}
//error_log(__METHOD__.__LINE__.$sessionData['to'].'->'.array2string($karr));
foreach ( array ( 'cc' , 'bcc' , 'subject' , 'body' ) as $name )
{
if ( $karr [ $name ]) $sessionData [ $name ] = $karr [ $name ];
}
if ( ! empty ( $_REQUEST [ 'subject' ])) $sessionData [ 'subject' ] = html :: purify ( trim ( html_entity_decode ( $_REQUEST [ 'subject' ])));
2011-07-01 12:37:47 +02:00
}
//is the MimeType set/requested
if ( ! empty ( $_REQUEST [ 'mimeType' ]))
{
$sessionData [ 'mimeType' ] = $_REQUEST [ 'mimeType' ];
}
2012-01-16 17:43:33 +01:00
else
{
// try to enforce a mimeType on reply ( if type is not of the wanted type )
if ( $isReply )
{
if ( ! empty ( $this -> bocompose -> preferencesArray [ 'replyOptions' ]) && $this -> bocompose -> preferencesArray [ 'replyOptions' ] == " text " &&
$sessionData [ 'mimeType' ] == 'html' )
{
$sessionData [ 'mimeType' ] = 'plain' ;
$sessionData [ 'body' ] = $this -> bocompose -> convertHTMLToText ( str_replace ( array ( " \n \r " , " \n " ), ' ' , $sessionData [ 'body' ]));
}
if ( ! empty ( $this -> bocompose -> preferencesArray [ 'replyOptions' ]) && $this -> bocompose -> preferencesArray [ 'replyOptions' ] == " html " &&
$sessionData [ 'mimeType' ] != 'html' )
{
$sessionData [ 'mimeType' ] = 'html' ;
$sessionData [ 'body' ] = " <pre> " . $sessionData [ 'body' ] . " </pre> " ;
2013-01-17 12:22:24 +01:00
// take care this assumption is made on the creation of the reply header in bocompose::getReplyData
if ( strpos ( $sessionData [ 'body' ], " <pre> \r \n \r \n --- " ) === 0 ) $sessionData [ 'body' ] = substr_replace ( $sessionData [ 'body' ], " <br> \r \n <pre>--- " , 0 , strlen ( " <pre> \r \n \r \n --- " ) - 1 );
2012-01-16 17:43:33 +01:00
}
}
}
2011-10-31 11:59:31 +01:00
if ( $sessionData [ 'mimeType' ] == 'html' && html :: htmlarea_availible () === false )
{
$sessionData [ 'mimeType' ] = 'plain' ;
$sessionData [ 'body' ] = $this -> bocompose -> convertHTMLToText ( $sessionData [ 'body' ]);
}
2012-10-31 15:35:13 +01:00
// removal of possible script elements in HTML; getCleanHTML is the choice here, if not only for consistence
// we use the preg of common_functions (slightly altered) to meet eGroupwares behavior on posted variables
if ( $sessionData [ 'mimeType' ] == 'html' )
{
// this is now moved to egw_htmLawed (triggered by default config) which is called with ckeditor anyway
//felamimail_bo::getCleanHTML($sessionData['body'],true);
}
2013-01-24 13:59:08 +01:00
2011-07-01 12:37:47 +02:00
// is a certain signature requested?
// only the following values are supported (and make sense)
// no => means -2
// system => means -1
// default => fetches the default, which is standard behavior
if ( ! empty ( $_REQUEST [ 'signature' ]) && ( strtolower ( $_REQUEST [ 'signature' ]) == 'no' || strtolower ( $_REQUEST [ 'signature' ]) == 'system' ))
{
$presetSig = ( strtolower ( $_REQUEST [ 'signature' ]) == 'no' ? - 2 : - 1 );
}
if (( $suppressSigOnTop || $sessionData [ 'isDraft' ]) && ! empty ( $sessionData [ 'signatureID' ])) $presetSig = ( int ) $sessionData [ 'signatureID' ];
if (( $suppressSigOnTop || $sessionData [ 'isDraft' ]) && ! empty ( $sessionData [ 'stationeryID' ])) $presetStationery = $sessionData [ 'stationeryID' ];
$presetId = NULL ;
if (( $suppressSigOnTop || $sessionData [ 'isDraft' ]) && ! empty ( $sessionData [ 'identity' ])) $presetId = ( int ) $sessionData [ 'identity' ];
$this -> display_app_header ();
$this -> t -> set_file ( array ( " composeForm " => " composeForm.tpl " ));
$this -> t -> set_block ( 'composeForm' , 'header' , 'header' );
$this -> t -> set_block ( 'composeForm' , 'body_input' );
$this -> t -> set_block ( 'composeForm' , 'attachment' , 'attachment' );
$this -> t -> set_block ( 'composeForm' , 'attachment_row' , 'attachment_row' );
$this -> t -> set_block ( 'composeForm' , 'attachment_row_bold' );
$this -> t -> set_block ( 'composeForm' , 'destination_row' );
$this -> t -> set_block ( 'composeForm' , 'simple_text' );
$this -> translate ();
// store the selected Signature
$this -> t -> set_var ( " mySigID " ,( $presetSig ? $presetSig : $sessionData [ 'signatureID' ]));
if ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'addressbook' ]) {
$this -> t -> set_var ( " link_addressbook " , egw :: link ( '/index.php' , array (
'menuaction' => 'addressbook.addressbook_ui.emailpopup' ,
)));
} else {
$this -> t -> set_var ( " link_addressbook " , '' );
}
$this -> t -> set_var ( " focusElement " , $_focusElement );
$linkData = array
(
'menuaction' => 'felamimail.uicompose.selectFolder' ,
);
$this -> t -> set_var ( 'folder_select_url' , egw :: link ( '/index.php' , $linkData ));
$linkData = array
(
'menuaction' => 'felamimail.uicompose.fileSelector' ,
'composeid' => $this -> composeID
);
$this -> t -> set_var ( 'file_selector_url' , egw :: link ( '/index.php' , $linkData ));
$this -> t -> set_var ( 'vfs_selector_url' , egw :: link ( '/index.php' , array (
'menuaction' => 'filemanager.filemanager_select.select' ,
'mode' => 'open-multiple' ,
'method' => 'felamimail.uicompose.vfsSelector' ,
'id' => $this -> composeID ,
'label' => lang ( 'Attach' ),
)));
if ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'filemanager' ])
{
$this -> t -> set_var ( 'vfs_attach_button' , '
< button class = " menuButton " type = " button " onclick = " fm_compose_displayVfsSelector(); " title = " '.htmlspecialchars(lang('filemanager')).' " >
< img src = " '.common::image('filemanager','navbar').' " height = " 18 " >
</ button > ' );
}
else
{
$this -> t -> set_var ( 'vfs_attach_button' , '' );
}
$linkData = array
(
'menuaction' => 'felamimail.uicompose.action' ,
'composeid' => $this -> composeID
);
$this -> t -> set_var ( " link_action " , egw :: link ( '/index.php' , $linkData ));
$this -> t -> set_var ( 'folder_name' , $this -> bofelamimail -> sessionData [ 'mailbox' ]);
$this -> t -> set_var ( 'compose_id' , $this -> composeID );
2013-03-15 09:34:53 +01:00
// the editorobject is needed all the time (since we use CKEDITOR
2011-07-01 12:37:47 +02:00
//$editorObject = html::initCKEditor('400px','simple');
2011-11-23 13:43:40 +01:00
$this -> t -> set_var ( 'ckeditorConfig' , egw_ckeditor_config :: get_ckeditor_config ( 'simple-withimage' )); //$editorObject->jsEncode($editorObject->config));
2012-03-16 10:59:26 +01:00
$this -> t -> set_var ( 'refreshTimeOut' , 3 * 60 * 1000 ); // 3 minutes till a compose messages will be saved as draft;
2011-07-01 12:37:47 +02:00
// check for some error messages from last posting attempt
2011-12-16 11:29:31 +01:00
$errorInfo = $this -> bocompose -> getErrorInfo ();
if ( isset ( $_REQUEST [ 'preset' ][ 'msg' ])) $errorInfo = html :: purify ( $_REQUEST [ 'preset' ][ 'msg' ]);
if ( $errorInfo )
2011-07-01 12:37:47 +02:00
{
$this -> t -> set_var ( 'errorInfo' , " <font color= \" red \" ><b> $errorInfo </b></font> " );
}
else
{
$this -> t -> set_var ( 'errorInfo' , ' ' );
}
// header
$allIdentities = $this -> mailPreferences -> getIdentity ();
2013-02-01 10:04:08 +01:00
unset ( $allIdentities [ 0 ]);
2011-07-01 12:37:47 +02:00
//_debug_array($allIdentities);
2013-02-07 09:47:43 +01:00
if ( is_null ( felamimail_bo :: $felamimailConfig )) felamimail_bo :: $felamimailConfig = config :: read ( 'felamimail' );
// not set? -> use default, means full display of all available data
if ( ! isset ( felamimail_bo :: $felamimailConfig [ 'how2displayIdentities' ])) felamimail_bo :: $felamimailConfig [ 'how2displayIdentities' ] = '' ;
$globalIds = 0 ;
2013-04-23 09:38:55 +02:00
$defaultIds = array ();
foreach ( $allIdentities as $key => $singleIdentity ) {
if ( $singleIdentity -> id < 0 ){ $globalIds ++ ; } /*else{ unset($allIdentities[$key]);}*/
// there could be up to 2 default IDS. the activeProfile and another on marking the desired Identity to choose
if ( ! empty ( $singleIdentity -> default ) && $singleIdentity -> default == 1 ) $defaultIds [ $singleIdentity -> id ] = $singleIdentity -> id ;
}
//error_log(__METHOD__.__LINE__.' Identities regarded/marked as default:'.array2string($defaultIds). ' MailProfileActive:'.$this->bofelamimail->profileID);
// if there are 2 defaultIDs, its most likely, that the user choose to set
// the one not being the activeServerProfile to be his default Identity
if ( count ( $defaultIds ) > 1 ) unset ( $defaultIds [ $this -> bofelamimail -> profileID ]);
2011-07-01 12:37:47 +02:00
$defaultIdentity = 0 ;
$identities = array ();
foreach ( $allIdentities as $key => $singleIdentity ) {
2013-02-01 10:04:08 +01:00
//$identities[$singleIdentity->id] = $singleIdentity->realName.' <'.$singleIdentity->emailAddress.'>';
$iS = felamimail_bo :: generateIdentityString ( $singleIdentity );
2013-02-07 09:47:43 +01:00
if ( felamimail_bo :: $felamimailConfig [ 'how2displayIdentities' ] == '' || count ( $allIdentities ) == 1 || count ( $allIdentities ) == $globalIds )
{
$id_prepend = '' ;
}
else
{
$id_prepend = '(' . $singleIdentity -> id . ') ' ;
}
2013-04-23 09:38:55 +02:00
//if ($singleIdentity->default) error_log(__METHOD__.__LINE__.':'.$presetId.'->'.$key.'('.$singleIdentity->id.')'.'#'.$iS.'#');
2013-02-07 09:47:43 +01:00
if ( array_search ( $id_prepend . $iS , $identities ) === false ) $identities [ $singleIdentity -> id ] = $id_prepend . $iS ;
2013-04-23 09:38:55 +02:00
if ( in_array ( $singleIdentity -> id , $defaultIds ) && $defaultIdentity == 0 )
2011-07-01 12:37:47 +02:00
{
2013-02-01 10:04:08 +01:00
//_debug_array($singleIdentity);
$defaultIdentity = $singleIdentity -> id ;
//$defaultIdentity = $key;
2011-07-01 12:37:47 +02:00
$sessionData [ 'signatureID' ] = ( ! empty ( $singleIdentity -> signature ) ? $singleIdentity -> signature : $sessionData [ 'signatureID' ]);
}
}
2013-02-01 10:04:08 +01:00
$selectFrom = html :: select ( 'identity' , ( ! empty ( $presetId ) ? $presetId : $defaultIdentity ), $identities , true , " style='width:100%;' onchange='changeIdentity(this);' " );
2011-07-01 12:37:47 +02:00
$this -> t -> set_var ( 'select_from' , $selectFrom );
//error_log(__METHOD__.__LINE__.' DefaultIdentity:'.array2string($identities[($presetId ? $presetId : $defaultIdentity)]));
// navbar(, kind of)
$this -> t -> set_var ( 'img_clear_left' , common :: image ( 'felamimail' , 'clear_left' ));
$this -> t -> set_var ( 'img_fileopen' , common :: image ( 'phpgwapi' , 'fileopen' ));
$this -> t -> set_var ( 'img_mail_send' , common :: image ( 'felamimail' , 'mail_send' ));
$this -> t -> set_var ( 'img_attach_file' , common :: image ( 'felamimail' , 'attach' ));
$this -> t -> set_var ( 'ajax-loader' , common :: image ( 'felamimail' , 'ajax-loader' ));
$this -> t -> set_var ( 'img_fileexport' , common :: image ( 'felamimail' , 'fileexport' ));
// prepare print url/button
$this -> t -> set_var ( 'img_print_it' , common :: image ( 'felamimail' , 'print' ));
$this -> t -> set_var ( 'lang_print_it' , lang ( 'print it' ));
$this -> t -> set_var ( 'print_it' , $printURL );
// from, to, cc, replyto
$destinationRows = 0 ;
foreach ( array ( 'to' , 'cc' , 'bcc' , 'replyto' , 'folder' ) as $destination ) {
foreach (( array ) $sessionData [ $destination ] as $key => $value ) {
if ( $value == " NIL@NIL " ) continue ;
if ( $destination == 'replyto' && str_replace ( '"' , '' , $value ) == str_replace ( '"' , '' , $identities [( $presetId ? $presetId : $defaultIdentity )])) continue ;
//error_log(__METHOD__.__LINE__.array2string(array('key'=>$key,'value'=>$value)));
$selectDestination = html :: select ( 'destination[]' , $destination , $this -> destinations , false , " style='width: 100%;' onchange='fm_compose_changeInputType(this)' " );
$this -> t -> set_var ( 'select_destination' , $selectDestination );
$value = htmlspecialchars_decode ( $value , ENT_COMPAT );
$value = str_replace ( " \" \" " , '"' , $value );
$address_array = imap_rfc822_parse_adrlist (( get_magic_quotes_gpc () ? stripslashes ( $value ) : $value ), '' );
foreach (( array ) $address_array as $addressObject ) {
if ( $addressObject -> host == '.SYNTAX-ERROR.' ) continue ;
$address = imap_rfc822_write_address ( $addressObject -> mailbox , $addressObject -> host , $addressObject -> personal );
$address = felamimail_bo :: htmlentities ( $address , $this -> displayCharset );
2012-03-22 15:31:56 +01:00
$this -> t -> set_var ( 'address' , ( $destination == 'folder' ? $value : $address ));
2011-07-01 12:37:47 +02:00
$this -> t -> parse ( 'destinationRows' , 'destination_row' , True );
$destinationRows ++ ;
}
}
}
while ( $destinationRows < 3 ) {
// and always add one empty row
$selectDestination = html :: select ( 'destination[]' , 'to' , $this -> destinations , false , " style='width: 100%;' onchange='fm_compose_changeInputType(this)' " );
$this -> t -> set_var ( 'select_destination' , $selectDestination );
$this -> t -> set_var ( 'address' , '' );
$this -> t -> parse ( 'destinationRows' , 'destination_row' , True );
$destinationRows ++ ;
}
// and always add one empty row
$selectDestination = html :: select ( 'destination[]' , 'to' , $this -> destinations , false , " style='width: 100%;' onchange='fm_compose_changeInputType(this)' " );
$this -> t -> set_var ( 'select_destination' , $selectDestination );
$this -> t -> set_var ( 'address' , '' );
$this -> t -> parse ( 'destinationRows' , 'destination_row' , True );
// handle subject
$subject = felamimail_bo :: htmlentities ( $sessionData [ 'subject' ], $this -> displayCharset );
$this -> t -> set_var ( " subject " , $subject );
if ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'addressbook' ]) {
$this -> t -> set_var ( 'addressbookButton' , '<button class="menuButton" type="button" onclick="addybook();" title="' . lang ( 'addressbook' ) . ' " >
< img src = " '.common::image('phpgwapi/templates/phpgw_website','users').' " >
</ button > ' );
} else {
$this -> t -> set_var ( 'addressbookButton' , '' );
}
if ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'infolog' ]) {
$this -> t -> set_var ( 'infologImage' , html :: image ( 'felamimail' , 'to_infolog' , lang ( 'Save as infolog' ), 'width="17px" height="17px" valign="middle"' ));
$this -> t -> set_var ( 'lang_save_as_infolog' , lang ( 'Save as infolog' ));
$this -> t -> set_var ( 'infolog_checkbox' , '<input class="input_text" type="checkbox" id="to_infolog" name="to_infolog" />' );
} else {
$this -> t -> set_var ( 'infologImage' , '' );
$this -> t -> set_var ( 'lang_save_as_infolog' , '' );
$this -> t -> set_var ( 'infolog_checkbox' , '' );
}
if ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'tracker' ])
{
$this -> t -> set_var ( 'trackerImage' , html :: image ( 'felamimail' , 'to_tracker' , lang ( 'Save as tracker' ), 'width="17px" height="17px" valign="middle"' ));
$this -> t -> set_var ( 'lang_save_as_infolog' ,( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'infolog' ] ? lang ( 'Save:' ) : lang ( 'Save as tracker' )));
$this -> t -> set_var ( 'tracker_checkbox' , '<input class="input_text" type="checkbox" id="to_tracker" name="to_tracker" />' );
} else {
$this -> t -> set_var ( 'trackerImage' , '' );
$this -> t -> set_var ( 'tracker_checkbox' , '' );
}
$this -> t -> set_var ( 'lang_no_recipient' , lang ( 'No recipient address given!' ));
$this -> t -> set_var ( 'lang_no_subject' , lang ( 'No subject given!' ));
$this -> t -> set_var ( 'lang_infolog_tracker_not_both' , lang ( " You can either choose to save as infolog OR tracker, not both. " ));
$this -> t -> pparse ( " out " , " header " );
// prepare signatures, the selected sig may be used on top of the body
require_once ( EGW_INCLUDE_ROOT . '/felamimail/inc/class.felamimail_bosignatures.inc.php' );
$boSignatures = new felamimail_bosignatures ();
$signatures = $boSignatures -> getListOfSignatures ();
if ( empty ( $sessionData [ 'signatureID' ])) {
if ( $signatureData = $boSignatures -> getDefaultSignature ()) {
if ( is_array ( $signatureData )) {
$sessionData [ 'signatureID' ] = $signatureData [ 'signatureid' ];
} else {
$sessionData [ 'signatureID' ] = $signatureData ;
}
}
}
$selectSignatures = array (
'-2' => lang ( 'no signature' )
);
foreach ( $signatures as $signature ) {
$selectSignatures [ $signature [ 'fm_signatureid' ]] = lang ( 'Signature' ) . ': ' . $signature [ 'fm_description' ];
}
$disableRuler = false ;
$signature = $boSignatures -> getSignature (( $presetSig ? $presetSig : $sessionData [ 'signatureID' ]));
if (( isset ( $this -> bocompose -> preferencesArray [ 'disableRulerForSignatureSeparation' ]) &&
$this -> bocompose -> preferencesArray [ 'disableRulerForSignatureSeparation' ]) ||
empty ( $signature -> fm_signature ) || trim ( $this -> bocompose -> convertHTMLToText ( $signature -> fm_signature )) == '' )
{
$disableRuler = true ;
}
2013-01-17 12:22:24 +01:00
$font_span = '' ;
if ( $sessionData [ 'mimeType' ] == 'html' /*&& trim($sessionData['body'])==''*/ ) {
// User preferences for style
$font = $GLOBALS [ 'egw_info' ][ 'user' ][ 'preferences' ][ 'common' ][ 'rte_font' ];
2013-02-21 14:23:52 +01:00
$font_size = egw_ckeditor_config :: font_size_from_prefs ();
2013-02-22 10:33:40 +01:00
$font_span = '<span ' . ( $font || $font_size ? 'style="' : '' ) . ( $font ? 'font-family:' . $font . '; ' : '' ) . ( $font_size ? 'font-size:' . $font_size . '; ' : '' ) . '">' . ' ' . '</span>' ;
2013-01-17 12:22:24 +01:00
if ( empty ( $font ) && empty ( $font_size )) $font_span = '' ;
2013-01-24 13:59:08 +01:00
}
2013-01-17 12:22:24 +01:00
//remove possible html header stuff
if ( stripos ( $sessionData [ 'body' ], '<html><head></head><body>' ) !== false ) $sessionData [ 'body' ] = str_ireplace ( array ( '<html><head></head><body>' , '</body></html>' ), array ( '' , '' ), $sessionData [ 'body' ]);
2011-07-01 12:37:47 +02:00
//error_log(__METHOD__.__LINE__.array2string($this->bocompose->preferencesArray));
2013-02-15 14:04:50 +01:00
$blockElements = array ( 'address' , 'blockquote' , 'center' , 'del' , 'dir' , 'div' , 'dl' , 'fieldset' , 'form' , 'h1' , 'h2' , 'h3' , 'h4' , 'h5' , 'h6' , 'hr' , 'ins' , 'isindex' , 'menu' , 'noframes' , 'noscript' , 'ol' , 'p' , 'pre' , 'table' , 'ul' );
2011-07-01 12:37:47 +02:00
if ( isset ( $this -> bocompose -> preferencesArray [ 'insertSignatureAtTopOfMessage' ]) &&
$this -> bocompose -> preferencesArray [ 'insertSignatureAtTopOfMessage' ] &&
! ( isset ( $_POST [ 'mySigID' ]) && ! empty ( $_POST [ 'mySigID' ]) ) && ! $suppressSigOnTop
)
{
2012-11-29 17:18:40 +01:00
$insertSigOnTop = ( $insertSigOnTop ? $insertSigOnTop : true );
2013-02-15 14:04:50 +01:00
$sigText = felamimail_bo :: merge ( $signature -> fm_signature , array ( $GLOBALS [ 'egw' ] -> accounts -> id2name ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'account_id' ], 'person_id' )));
if ( $sessionData [ 'mimeType' ] == 'html' )
{
$sigTextStartsWithBlockElement = ( $disableRuler ? false : true );
foreach ( $blockElements as $e )
{
if ( $sigTextStartsWithBlockElement ) break ;
if ( stripos ( trim ( $sigText ), '<' . $e ) === 0 ) $sigTextStartsWithBlockElement = true ;
}
}
2011-07-01 12:37:47 +02:00
if ( $sessionData [ 'mimeType' ] == 'html' ) {
2013-02-15 14:04:50 +01:00
$before = ( ! empty ( $font_span ) && ! ( $insertSigOnTop === 'below' ) ? $font_span : ' ' ) . ( $disableRuler ? '' /*($sigTextStartsWithBlockElement?'':'<p style="margin:0px;"/>')*/ : '<hr style="border:1px dotted silver; width:90%;">' );
2011-07-01 12:37:47 +02:00
$inbetween = ' <br>' ;
} else {
$before = ( $disableRuler ? " \r \n \r \n " : " \r \n \r \n -- \r \n " );
$inbetween = " \r \n " ;
}
2013-02-15 14:04:50 +01:00
if ( $sessionData [ 'mimeType' ] == 'html' )
{
$sigText = ( $sigTextStartsWithBlockElement ? '' : " <div> " ) . " <!-- HTMLSIGBEGIN --> " . $sigText . " <!-- HTMLSIGEND --> " . ( $sigTextStartsWithBlockElement ? '' : " </div> " );
}
2012-11-29 17:18:40 +01:00
if ( $insertSigOnTop === 'below' )
{
2013-02-15 14:04:50 +01:00
$sessionData [ 'body' ] = $font_span . $sessionData [ 'body' ] . $before . ( $sessionData [ 'mimeType' ] == 'html' ? $sigText : $this -> bocompose -> convertHTMLToText ( $sigText ));
2012-11-29 17:18:40 +01:00
}
else
{
$sessionData [ 'body' ] = $before . ( $sessionData [ 'mimeType' ] == 'html' ? $sigText : $this -> bocompose -> convertHTMLToText ( $sigText )) . $inbetween . $sessionData [ 'body' ];
}
2011-07-01 12:37:47 +02:00
}
2013-01-17 12:22:24 +01:00
else
{
2013-03-22 11:37:11 +01:00
$sessionData [ 'body' ] = ( $font_span ? $font_span : ' ' ) . $sessionData [ 'body' ];
2013-01-17 12:22:24 +01:00
}
//error_log(__METHOD__.__LINE__.$sessionData['body']);
2011-07-01 12:37:47 +02:00
// prepare body
2012-09-25 15:27:52 +02:00
// in a way, this tests if we are having real utf-8 (the displayCharset) by now; we should if charsets reported (or detected) are correct
if ( strtoupper ( $this -> displayCharset ) == 'UTF-8' )
{
$test = @ json_encode ( $sessionData [ 'body' ]);
//error_log(__METHOD__.__LINE__.' ->'.strlen($singleBodyPart['body']).' Error:'.json_last_error().'<- BodyPart:#'.$test.'#');
//if (json_last_error() != JSON_ERROR_NONE && strlen($singleBodyPart['body'])>0)
if ( $test == " null " && strlen ( $sessionData [ 'body' ]) > 0 )
{
// this should not be needed, unless something fails with charset detection/ wrong charset passed
error_log ( __METHOD__ . __LINE__ . ' Charset problem detected; Charset Detected:' . felamimail_bo :: detect_encoding ( $sessionData [ 'body' ]));
$sessionData [ 'body' ] = utf8_encode ( $sessionData [ 'body' ]);
}
}
2013-02-15 14:04:50 +01:00
//error_log(__METHOD__.__LINE__.$sessionData['body']);
2011-07-01 12:37:47 +02:00
if ( $sessionData [ 'mimeType' ] == 'html' ) {
2011-11-23 13:43:40 +01:00
$mode = 'simple-withimage' ;
2012-10-31 15:35:13 +01:00
//$mode ='advanced';// most helpful for debuging
2011-07-01 12:37:47 +02:00
#if (isset($GLOBALS['egw_info']['server']['enabled_spellcheck'])) $mode = 'egw_simple_spellcheck';
2013-04-29 15:03:42 +02:00
$style = " border:0px; width:100%; height:500px; " ;
2011-07-01 12:37:47 +02:00
// dont run purify, as we already did that (getCleanHTML).
2013-04-29 15:03:42 +02:00
$this -> t -> set_var ( 'tinymce' , html :: fckEditorQuick ( 'body' , $mode , $sessionData [ 'body' ], '500px' , '100%' , false , '0px' ,( $_focusElement == 'body' ? true : false ),( $_focusElement != 'body' ? 'parent.setToFocus("' . $_focusElement . '");' : '' )));
2011-07-01 12:37:47 +02:00
$this -> t -> set_var ( 'mimeType' , 'html' );
$ishtml = 1 ;
} else {
2012-08-15 16:56:37 +02:00
$border = " 1px solid gray; margin:1px " ;
2011-07-01 12:37:47 +02:00
// initalize the CKEditor Object to enable switching back and force
2013-04-29 15:03:42 +02:00
$editor = html :: fckEditorQuick ( 'body' , 'ascii' , $sessionData [ 'body' ], '500px' , '99%' , false , $border );
2011-07-01 12:37:47 +02:00
$this -> t -> set_var ( 'tinymce' , $editor ); //html::fckEditorQuick('body', 'ascii', $sessionData['body'],'400px','99%'));
$this -> t -> set_var ( 'mimeType' , 'text' );
$ishtml = 0 ;
}
$bostationery = new felamimail_bostationery ();
$selectStationeries = array (
'0' => lang ( 'no stationery' )
);
$showStationaries = false ;
$validStationaries = $bostationery -> get_valid_templates ();
if ( is_array ( $validStationaries ) && count ( $validStationaries ) > 0 )
{
$showStationaries = true ;
$selectStationeries += $validStationaries ;
}
// if ID of signature Select Box is set, we allow for changing the sig onChange of the signatueSelect
$selectBoxSignature = html :: select ( 'signatureID' , ( $presetSig ? $presetSig : $sessionData [ 'signatureID' ]), $selectSignatures , true , ( $insertSigOnTop ? " id='signatureID' " : " " ) . " style='width: 35%;' onchange='fm_compose_changeInputType(this)' " );
$selectBoxStationery = html :: select ( 'stationeryID' , ( $presetStationery ? $presetStationery : 0 ), $selectStationeries , true , " style='width: 35%;' " );
$this -> t -> set_var ( " select_signature " , $selectBoxSignature );
$this -> t -> set_var ( " select_stationery " , ( $showStationaries ? $selectBoxStationery : '' ));
$this -> t -> set_var ( " lang_editormode " , lang ( " Editor type " ));
2011-10-31 11:59:31 +01:00
if ( html :: htmlarea_availible () === false )
{
$this -> t -> set_var ( " toggle_editormode " , '' );
}
else
2011-11-29 13:09:29 +01:00
{
2011-12-29 12:20:13 +01:00
// IE seems to need onclick to realize there is a change
$this -> t -> set_var ( " toggle_editormode " , lang ( " Editor type " ) . " : <span><input name= \" _is_html \" value= \" " . $ishtml . " \" type= \" hidden \" /><input name= \" _editorselect \" onchange= \" fm_toggle_editor(this) \" onclick= \" fm_toggle_editor(this) \" " . ( $ishtml ? " checked= \" checked \" " : " " ) . " id= \" _html \" value= \" html \" type= \" radio \" ><label for= \" _html \" >HTML</label><input name= \" _editorselect \" onchange= \" fm_toggle_editor(this) \" onclick= \" fm_toggle_editor(this) \" " . ( $ishtml ? " " : " checked= \" checked \" " ) . " id= \" _plain \" value= \" plain \" type= \" radio \" ><label for= \" _plain \" >Plain text</label></span> " );
2011-10-31 11:59:31 +01:00
}
2011-07-01 12:37:47 +02:00
$this -> t -> pparse ( " out " , " body_input " );
// attachments
if ( is_array ( $sessionData [ 'attachments' ]) && count ( $sessionData [ 'attachments' ]) > 0 )
{
$imgClearLeft = common :: image ( 'felamimail' , 'clear_left' );
2011-12-19 13:40:47 +01:00
$tableRows = array ();
2011-07-01 12:37:47 +02:00
foreach (( array ) $sessionData [ 'attachments' ] as $id => $attachment ) {
$tempArray = array (
'1' => $attachment [ 'name' ], '.1' => 'width="40%"' ,
'2' => mime_magic :: mime2label ( $attachment [ 'type' ]),
'3' => egw_vfs :: hsize ( $attachment [ 'size' ]), '.3' => " style='text-align:right;' " ,
'4' => ' ' , '.4' => 'width="10%"' ,
'5' => " <img src=' $imgClearLeft ' onclick= \" fm_compose_deleteAttachmentRow(this,' " . $this -> composeID . " ',' $id ') \" > " ,
);
$tableRows [] = $tempArray ;
}
if ( count ( $tableRows ) > 0 ) {
$table = html :: table ( $tableRows , " style='width:100%' " );
}
$this -> t -> set_var ( 'attachment_rows' , $table );
}
else
{
$this -> t -> set_var ( 'attachment_rows' , '' );
}
$this -> t -> pparse ( " out " , " attachment " );
}
function composeFromDraft () {
$icServer = ( int ) $_GET [ 'icServer' ];
2012-11-05 09:58:03 +01:00
$folder = ( isset ( $_GET [ 'folder' ]) ? base64_decode ( $_GET [ 'folder' ]) : base64_decode ( $_GET [ 'mailbox' ]));
2011-07-01 12:37:47 +02:00
$replyID = $_GET [ 'uid' ];
if ( ! empty ( $folder ) && ! empty ( $replyID ) ) {
// this fill the session data with the values from the original email
$this -> bocompose -> getDraftData ( $icServer , $folder , $replyID );
}
$this -> compose ( 'body' , $suppressSigOnTop = true );
}
function display_app_header ()
{
egw_framework :: validate_file ( 'jscode' , 'composeMessage' , 'felamimail' );
2013-03-15 09:34:53 +01:00
egw_framework :: validate_file ( 'ckeditor' , 'ckeditor' , 'phpgwapi' );
2011-07-01 12:37:47 +02:00
$GLOBALS [ 'egw' ] -> js -> set_onload ( 'javascript:initAll();' );
2012-10-31 15:35:13 +01:00
$GLOBALS [ 'egw' ] -> js -> set_onbeforeunload ( " if (do_onunload && justClickedSend==false) if (draftsMayExist) { a = checkunload(browserSupportsOnUnloadConfirm?' " . addslashes ( lang ( " Please choose: " )) . " '+' \\ n'+' " . addslashes ( lang ( " 1) keep drafted message (press OK) " )) . " '+' \\ n'+' " . addslashes ( lang ( " 2) discard the message completely (press Cancel) " )) . " ':' " . addslashes ( lang ( " if you leave this page without saving to draft, the message will be discarded completely " )) . " '); " . ' if (!browserSupportsOnUnloadConfirm) return a;}' );
2012-03-22 13:23:11 +01:00
//$GLOBALS['egw']->js->set_onbeforeunload("if (do_onunload) if (draftsMayExist) return '".addslashes(lang("Please choose:"))."'+'\\n'+'".addslashes(lang("1) keep drafted message (press OK)"))."'+'\\n'+'".addslashes(lang("2) discard the message completely (press Cancel)"))."';");
2012-10-31 15:35:13 +01:00
$GLOBALS [ 'egw' ] -> js -> set_onunload ( " if (do_onunload && justClickedSend==false) checkunload(); " );
2012-03-22 13:23:11 +01:00
//$GLOBALS['egw']->js->set_onunload("if (do_onunload) egw_appWindow('felamimail').xajax_doXMLHTTPsync('felamimail.ajaxfelamimail.removeLastDraftedVersion','".$this->composeID."');");
2011-07-01 12:37:47 +02:00
$GLOBALS [ 'egw_info' ][ 'flags' ][ 'include_xajax' ] = True ;
common :: egw_header ();
}
/**
* Callback for filemanagers select file dialog
*
* @ param string $composeid
* @ param string | array $files path of file ( s ) in vfs ( no egw_vfs :: PREFIX , just the path )
* @ return string javascript output by the file select dialog , usually to close it
*/
function vfsSelector ( $composeid , $files )
{
$this -> bocompose = CreateObject ( 'felamimail.bocompose' , $this -> composeID = $composeid , $this -> displayCharset );
foreach (( array ) $files as $path )
{
$formData = array (
'name' => egw_vfs :: basename ( $path ),
'type' => egw_vfs :: mime_content_type ( $path ),
'file' => egw_vfs :: PREFIX . $path ,
'size' => filesize ( egw_vfs :: PREFIX . $path ),
);
$this -> bocompose -> addAttachment ( $formData );
}
return 'window.close();' ;
}
function fileSelector ()
{
if ( is_array ( $_FILES [ " addFileName " ])) {
#phpinfo();
//_debug_array($_FILES);
$success = false ;
if ( is_array ( $_FILES [ " addFileName " ][ 'name' ]))
{
// multiple uploads supported by newer firefox (>3.6) and chrome (>4) versions,
// upload array information is by key within the attribute (name, type, size, temp_name)
foreach ( $_FILES [ " addFileName " ][ 'name' ] as $key => $filename )
{
if ( $_FILES [ 'addFileName' ][ 'error' ][ $key ] == $UPLOAD_ERR_OK ) {
$formData [ 'name' ] = $_FILES [ 'addFileName' ][ 'name' ][ $key ];
$formData [ 'type' ] = $_FILES [ 'addFileName' ][ 'type' ][ $key ];
$formData [ 'file' ] = $_FILES [ 'addFileName' ][ 'tmp_name' ][ $key ];
$formData [ 'size' ] = $_FILES [ 'addFileName' ][ 'size' ][ $key ];
$this -> bocompose -> addAttachment ( $formData );
$success = true ;
}
}
}
else // should not happen as upload form name is defined as addFileName[]
{
if ( $_FILES [ 'addFileName' ][ 'error' ] == $UPLOAD_ERR_OK ) {
$formData [ 'name' ] = $_FILES [ 'addFileName' ][ 'name' ];
$formData [ 'type' ] = $_FILES [ 'addFileName' ][ 'type' ];
$formData [ 'file' ] = $_FILES [ 'addFileName' ][ 'tmp_name' ];
$formData [ 'size' ] = $_FILES [ 'addFileName' ][ 'size' ];
$this -> bocompose -> addAttachment ( $formData );
$success = true ;
}
}
if ( $success == true )
{
print " <script type='text/javascript'>window.close();</script> " ;
}
else
{
print " <script type='text/javascript'>document.getElementById('fileSelectorDIV1').style.display = 'inline';document.getElementById('fileSelectorDIV2').style.display = 'none';</script> " ;
}
}
// this call loads js and css for the treeobject
html :: tree ( false , false , false , null , 'foldertree' , '' , '' , false , '/' , null , false );
egw_framework :: validate_file ( 'jscode' , 'composeMessage' , 'felamimail' );
common :: egw_header ();
#$uiwidgets =& CreateObject('felamimail.uiwidgets');
$this -> t -> set_file ( array ( " composeForm " => " composeForm.tpl " ));
$this -> t -> set_block ( 'composeForm' , 'fileSelector' , 'fileSelector' );
$this -> translate ();
$linkData = array
(
'menuaction' => 'felamimail.uicompose.fileSelector' ,
'composeid' => $this -> composeID
);
$this -> t -> set_var ( 'file_selector_url' , egw :: link ( '/index.php' , $linkData ));
$maxUploadSize = ini_get ( 'upload_max_filesize' );
$this -> t -> set_var ( 'max_uploadsize' , $maxUploadSize );
$this -> t -> set_var ( 'ajax-loader' , common :: image ( 'felamimail' , 'ajax-loader' ));
$this -> t -> pparse ( " out " , " fileSelector " );
}
function forward () {
$icServer = ( int ) $_GET [ 'icServer' ];
$folder = base64_decode ( $_GET [ 'folder' ]);
$replyID = $_GET [ 'reply_id' ];
$partID = $_GET [ 'part_id' ];
2012-03-29 14:20:56 +02:00
$mode = false ;
if ( isset ( $_GET [ 'mode' ]) && ( $_GET [ 'mode' ] == 'forwardasattach' || $_GET [ 'mode' ] == 'forwardinline' )) $mode = ( $_GET [ 'mode' ] == 'forwardinline' ? 'inline' : 'asattach' );
2011-07-01 12:37:47 +02:00
if ( ! empty ( $replyID ))
{
// this fill the session data with the values from the original email
2012-03-29 14:20:56 +02:00
$this -> bocompose -> getForwardData ( $icServer , $folder , $replyID , $partID , $mode );
2011-07-01 12:37:47 +02:00
}
2013-05-02 13:51:37 +02:00
$handleAsReply = ( $mode ? $mode == 'inline' : $this -> bocompose -> preferencesArray [ 'message_forwarding' ] == 'inline' );
$this -> compose ( 'to' , false , $handleAsReply );
2011-07-01 12:37:47 +02:00
}
function getAttachment ()
{
$bocompose = CreateObject ( 'felamimail.bocompose' , $_GET [ '_composeID' ]);
$attachment = $bocompose -> sessionData [ 'attachments' ][ $_GET [ 'attID' ]] ;
if ( ! empty ( $attachment [ 'folder' ]))
{
$is_winmail = $_GET [ 'is_winmail' ] ? $_GET [ 'is_winmail' ] : 0 ;
$this -> mailbox = $attachment [ 'folder' ];
$this -> bofelamimail -> reopen ( $this -> mailbox );
#$attachment = $this->bofelamimail->getAttachment($this->uid,$part);
$attachmentData = $this -> bofelamimail -> getAttachment ( $attachment [ 'uid' ], $attachment [ 'partID' ], $is_winmail );
$this -> bofelamimail -> closeConnection ();
}
if ( parse_url ( $attachment [ 'file' ], PHP_URL_SCHEME ) == 'vfs' )
{
egw_vfs :: load_wrapper ( 'vfs' );
}
//error_log(print_r($attachmentData,true));
header ( " Content-Type: " . $attachment [ 'type' ] . " ; name= \" " . $this -> bofelamimail -> decode_header ( $attachment [ 'name' ]) . " \" " );
header ( " Content-Disposition: inline; filename= \" " . $this -> bofelamimail -> decode_header ( $attachment [ 'name' ]) . " \" " );
header ( " Expires: 0 " );
header ( " Cache-Control: must-revalidate, post-check=0, pre-check=0 " );
header ( " Pragma: public " );
if ( ! empty ( $attachment [ 'file' ]))
{
$fp = fopen ( $attachment [ 'file' ], 'rb' );
fpassthru ( $fp );
fclose ( $fp );
}
else
{
echo $attachmentData [ 'attachment' ];
}
common :: egw_exit ();
exit ;
}
function selectFolder ()
{
// this call loads js and css for the treeobject
html :: tree ( false , false , false , null , 'foldertree' , '' , '' , false , '/' , null , false );
egw_framework :: validate_file ( 'jscode' , 'composeMessage' , 'felamimail' );
common :: egw_header ();
$bofelamimail = $this -> bofelamimail ;
$uiwidgets = CreateObject ( 'felamimail.uiwidgets' );
$connectionStatus = $bofelamimail -> openConnection ( $bofelamimail -> profileID );
$folderObjects = $bofelamimail -> getFolderObjects ( true , false );
$folderTree = $uiwidgets -> createHTMLFolder
(
$folderObjects ,
'INBOX' ,
0 ,
lang ( 'IMAP Server' ),
$mailPreferences [ 'username' ] . '@' . $mailPreferences [ 'imapServerAddress' ],
'divFolderTree' ,
2013-04-24 11:59:09 +02:00
false //,
//true
2011-07-01 12:37:47 +02:00
);
2012-07-12 15:58:12 +02:00
print '<div id="divFolderTree" style="overflow:auto; width:320px; height:450px; margin-bottom:0px; padding-left:0px; padding-top:0px; z-index:100; border:1px solid Silver;"></div>' ;
2011-07-01 12:37:47 +02:00
print $folderTree ;
}
function composeAsNew () {
$icServer = ( int ) $_GET [ 'icServer' ];
2012-11-05 09:58:03 +01:00
$folder = ( isset ( $_GET [ 'folder' ]) ? base64_decode ( $_GET [ 'folder' ]) : base64_decode ( $_GET [ 'mailbox' ]));
2011-07-01 12:37:47 +02:00
$replyID = $_GET [ 'reply_id' ];
$partID = $_GET [ 'part_id' ];
if ( ! empty ( $folder ) && ! empty ( $replyID ) ) {
// this fill the session data with the values from the original email
$this -> bocompose -> getDraftData ( $icServer , $folder , $replyID , $partID );
}
$this -> compose ( 'body' , true );
}
function reply () {
$icServer = ( int ) $_GET [ 'icServer' ];
$folder = base64_decode ( $_GET [ 'folder' ]);
$replyID = $_GET [ 'reply_id' ];
$partID = $_GET [ 'part_id' ];
if ( ! empty ( $folder ) && ! empty ( $replyID ) ) {
// this fill the session data with the values from the original email
$this -> bocompose -> getReplyData ( 'single' , $icServer , $folder , $replyID , $partID );
}
2012-01-16 17:43:33 +01:00
$this -> compose ( 'body' , false , true );
2011-07-01 12:37:47 +02:00
}
function replyAll () {
$icServer = ( int ) $_GET [ 'icServer' ];
$folder = base64_decode ( $_GET [ 'folder' ]);
$replyID = $_GET [ 'reply_id' ];
$partID = $_GET [ 'part_id' ];
if ( ! empty ( $folder ) && ! empty ( $replyID ) ) {
// this fill the session data with the values from the original email
$this -> bocompose -> getReplyData ( 'all' , $icServer , $folder , $replyID , $partID );
}
2012-01-16 17:43:33 +01:00
$this -> compose ( 'body' , false , true );
2011-07-01 12:37:47 +02:00
}
function translate () {
$this -> t -> set_var ( " lang_message_list " , lang ( 'Message List' ));
$this -> t -> set_var ( " lang_to " , lang ( 'to' ));
$this -> t -> set_var ( " lang_cc " , lang ( 'cc' ));
$this -> t -> set_var ( " lang_bcc " , lang ( 'bcc' ));
$this -> t -> set_var ( " lang_identity " , lang ( 'identity' ));
$this -> t -> set_var ( " lang_reply_to " , lang ( 'reply to' ));
$this -> t -> set_var ( " lang_subject " , lang ( 'subject' ));
$this -> t -> set_var ( " lang_addressbook " , lang ( 'addressbook' ));
$this -> t -> set_var ( " lang_search " , lang ( 'search' ));
$this -> t -> set_var ( " lang_send " , lang ( 'send' ));
$this -> t -> set_var ( 'lang_save_as_draft' , lang ( 'save as draft' ));
$this -> t -> set_var ( " lang_back_to_folder " , lang ( 'back to folder' ));
$this -> t -> set_var ( " lang_attachments " , lang ( 'attachments' ));
$this -> t -> set_var ( " lang_add " , lang ( 'add' ));
$this -> t -> set_var ( " lang_remove " , lang ( 'remove' ));
$this -> t -> set_var ( " lang_priority " , lang ( 'priority' ));
$this -> t -> set_var ( " lang_normal " , lang ( 'normal' ));
$this -> t -> set_var ( " lang_high " , lang ( 'high' ));
$this -> t -> set_var ( " lang_low " , lang ( 'low' ));
$this -> t -> set_var ( " lang_signature " , lang ( 'signature' ));
$this -> t -> set_var ( " lang_stationery " , lang ( 'stationery' ));
$this -> t -> set_var ( " lang_select_folder " , lang ( 'select folder' ));
$this -> t -> set_var ( 'lang_max_uploadsize' , lang ( 'max uploadsize' ));
$this -> t -> set_var ( 'lang_adding_file_please_wait' , lang ( 'Adding file to message. Please wait!' ));
$this -> t -> set_var ( 'lang_receive_notification' , lang ( 'Receive notification' ));
$this -> t -> set_var ( 'lang_no_address_set' , lang ( 'can not send message. no recipient defined!' ));
$this -> t -> set_var ( " th_bg " , $GLOBALS [ 'egw_info' ][ " theme " ][ " th_bg " ]);
$this -> t -> set_var ( " bg01 " , $GLOBALS [ 'egw_info' ][ " theme " ][ " bg01 " ]);
$this -> t -> set_var ( " bg02 " , $GLOBALS [ 'egw_info' ][ " theme " ][ " bg02 " ]);
$this -> t -> set_var ( " bg03 " , $GLOBALS [ 'egw_info' ][ " theme " ][ " bg03 " ]);
}
}
?>