loadMFP(); if($mfp != null) { $_REQUEST['description'] = $mfp->parseText($_REQUEST['description']); $_REQUEST['name'] = $mfp->parseText($_REQUEST['name']); $_POST['description'] = $_REQUEST['description']; $_POST['name'] = $_REQUEST['name']; } } $user_attachment = array(); if(isset($_REQUEST['user_attachment']) && is_array($_REQUEST['user_attachment'])) { $user_attachment_tmp = $_REQUEST['user_attachment']; if(isset($_REQUEST['user_remove_attachment']) && is_array($_REQUEST['user_remove_attachment'])) $user_attachment_tmp = array_diff($user_attachment_tmp, $_REQUEST['user_remove_attachment']); $user_attachment = $user_attachment_tmp; } require_once('modules/Emails/Email.php'); /////////////////////////////////////////////////////////////////////////////// //// EMAIL SEND/SAVE SETUP $focus = new Email(); if(!isset($prefix)) { $prefix = ''; } if(isset($_POST[$prefix.'meridiem']) && !empty($_POST[$prefix.'meridiem'])) { $_POST[$prefix.'time_start'] = $timedate->merge_time_meridiem($_POST[$prefix.'time_start'], $timedate->get_time_format(true), $_POST[$prefix.'meridiem']); } //retrieve the record if(isset($_POST['record']) && !empty($_POST['record'])) { $focus->retrieve($_POST['record']); } if(isset($_REQUEST['user_id'])) { $focus->assigned_user_id = $_REQUEST['user_id']; } if(!$focus->ACLAccess('Save')){ ACLController::displayNoAccess(true); sugar_cleanup(true); } if(!empty($_POST['assigned_user_id']) && ($focus->assigned_user_id != $_POST['assigned_user_id']) && ($_POST['assigned_user_id'] != $current_user->id)) { $check_notify = TRUE; } //populate the fields of this Email $allfields = array_merge($focus->column_fields, $focus->additional_column_fields); foreach($allfields as $field) { if(isset($_POST[$field])) { $value = $_POST[$field]; $focus->$field = $value; } } if (!isset($_REQUEST['to_addrs'])) { $_REQUEST['to_addrs'] = ""; } if (!isset($_REQUEST['to_addrs_ids'])) { $_REQUEST['to_addrs_ids'] = ""; } if (!isset($_REQUEST['to_addrs_names'])) { $_REQUEST['to_addrs_names'] = ""; } if (!isset($_REQUEST['to_addrs_emails'])) { $_REQUEST['to_addrs_emails'] = ""; } //GROUP ACCOUNTS SENDING// $cacc=$_REQUEST['accounts_count']; //if($cacc>0){ $i=0; while($i!=$cacc){ $i++; //account $acc_id=$_REQUEST['account_id_'.$i]; if($_REQUEST['account_name_'.$i])$acc[$acc_id]['name']=$_REQUEST['account_name_'.$i]; else continue; $j=-1; while($j!=100){ $j++; if($_REQUEST['account_email_check_'.$i.'_'.$j]){ $acc[$acc_id]['addrs'][]=$_REQUEST['account_email_check_'.$i.'_'.$j]; $em.=$_REQUEST['account_email_check_'.$i.'_'.$j]."; "; } } //cnt $j=-1; while($j!=100){ $j++; $cnt_id=$_REQUEST['contact_id_'.$i.'_'.$j]; if($_REQUEST['contact_name_'.$i.'_'.$j] && $_REQUEST['contact_id_'.$i.'_'.$j]){ $cnt[$cnt_id]['name']=$_REQUEST['contact_name_'.$i.'_'.$j]; $n=1; while($n!=100){ $n++; if($_REQUEST['contact_email_check_'.$i.'_'.$j.'_'.$n]){ $cnt[$cnt_id]['addrs'][]=$_REQUEST['contact_email_check_'.$i.'_'.$j.'_'.$n]; $em.=$_REQUEST['contact_email_check_'.$i.'_'.$j.'_'.$n]."; "; } } } } //acc $j=-1; while($j!=100){ $j++; $ac_id=$_REQUEST['acc_id_'.$i.'_'.$j]; if($_REQUEST['acc_name_'.$i.'_'.$j] && $_REQUEST['acc_id_'.$i.'_'.$j]){ $ac[$ac_id]['name']=$_REQUEST['acc_name_'.$i.'_'.$j]; $n=1; while($n!=100){ $n++; if($_REQUEST['acc_email_check_'.$i.'_'.$j.'_'.$n]){ $ac[$ac_id]['addrs'][]=$_REQUEST['acc_email_check_'.$i.'_'.$j.'_'.$n]; $em.=$_REQUEST['acc_email_check_'.$i.'_'.$j.'_'.$n]."; "; } } } } $acc[$acc_id]['contacts']=$cnt; $acc[$acc_id]['accounts']=$ac; } //} /*print_r($_REQUEST); print '
'.'acc_email_'.$i.'_'.$j.'_'.$n; print_r($acc); print $em."
"; die();*/ $_REQUEST['to_addrs'].="; ".$em; $_REQUEST['to_addrs_emails'].="; ".$em; $_REQUEST['to_addrs_ids'].="; ".$emids; $_REQUEST['to_addrs_namess'].="; ".$emids; ////////////////////////// if($_REQUEST['group']){ //foreach($_REQUEST['group'] as $gr){ $w=$GLOBALS['db']->query("select account_id from ecmemailgroups_accounts where ecmemailgroup_id='".$_REQUEST['group']."' and deleted='0'"); while($r=$GLOBALS['db']->fetchByAssoc($w)){ $rr=$GLOBALS['db']->fetchByAssoc($GLOBALS['db']->query( "select email_addresses.email_address as addr from email_addr_bean_rel inner join email_addresses on email_addresses.id=email_addr_bean_rel.email_address_id where email_addr_bean_rel.bean_module='Accounts' and email_addr_bean_rel.bean_id='".$r['account_id']."' and email_addr_bean_rel.deleted='0' and email_addresses.deleted='0'")); if($rr['addr']){ $em.=$rr['addr']."; "; $emids.=$r['account_id']."; "; $rrr=$GLOBALS['db']->fetchByAssoc($GLOBALS['db']->query("select name from accounts where id='".$r['account_id']."'")); $emnames.=$rrr['name']."; "; } } $w=$GLOBALS['db']->query("select contact_id from ecmemailgroups_contacts where ecmemailgroup_id='".$_REQUEST['group']."' and deleted='0'"); while($r=$GLOBALS['db']->fetchByAssoc($w)){ $rr=$GLOBALS['db']->fetchByAssoc($GLOBALS['db']->query( "select email_addresses.email_address as addr from email_addr_bean_rel inner join email_addresses on email_addresses.id=email_addr_bean_rel.email_address_id where email_addr_bean_rel.bean_module='Contacts' and email_addr_bean_rel.bean_id='".$r['contact_id']."' and email_addr_bean_rel.deleted='0' and email_addresses.deleted='0'")); if($rr['addr']){ $em.=$rr['addr']."; "; $emids.=$r['contact_id']."; "; $rrr=$GLOBALS['db']->fetchByAssoc($GLOBALS['db']->query("select first_name,last_name from contacts where id='".$r['contact_id']."'")); $emnames.=$rrr['first_name']." ".$rrr['last_name']."; "; } } //} $_REQUEST['to_addrs'].="; ".$em; $_REQUEST['to_addrs_emails'].="; ".$em; $_REQUEST['to_addrs_ids'].="; ".$emids; $_REQUEST['to_addrs_namess'].="; ".$emids; } //compare the 3 fields and return list of contact_ids to link: $focus->to_addrs_arr = $focus->parse_addrs($_REQUEST['to_addrs'], $_REQUEST['to_addrs_ids'], $_REQUEST['to_addrs_names'], $_REQUEST['to_addrs_emails']); // make sure the cc_* and bcc_* fields are at least empty if not set $fields_to_check = array( 'cc_addrs', 'cc_addrs_ids', 'bcc_addrs', 'bcc_addrs_ids', 'cc_addrs_names', 'cc_addrs_emails', 'bcc_addrs_emails', ); foreach ($fields_to_check as $field_to_check) { if (!isset($_REQUEST[$field_to_check])) { $_REQUEST[$field_to_check] = ''; } } $focus->cc_addrs_arr = $focus->parse_addrs($_REQUEST['cc_addrs'], $_REQUEST['cc_addrs_ids'], $_REQUEST['cc_addrs_names'], $_REQUEST['cc_addrs_emails']); $focus->bcc_addrs_arr = $focus->parse_addrs($_REQUEST['bcc_addrs'], $_REQUEST['bcc_addrs_ids'], $_REQUEST['to_addrs_names'], $_REQUEST['bcc_addrs_emails']); if(!empty($_REQUEST['type'])) { $focus->type = $_REQUEST['type']; } elseif(empty($focus->type)) { // cn: from drafts/quotes $focus->type = 'archived'; } /////////////////////////////////////////////////////////////////////////////// //// TEMPLATE PARSING // cn: bug 7244 - need to pass an empty bean to parse email templates $object_arr = array(); if(!empty($focus->parent_id)) { $object_arr[$focus->parent_type] = $focus->parent_id; } if(isset($focus->to_addrs_arr[0]['contact_id'])) { $object_arr['Contacts'] = $focus->to_addrs_arr[0]['contact_id']; } if(empty($object_arr)) { $object_arr = array('Contacts' => '123'); } // do not parse email templates if the email is being saved as draft.... if($focus->type != 'draft' && count($object_arr) > 0) { require_once($beanFiles['EmailTemplate']); $focus->name = EmailTemplate::parse_template($focus->name, $object_arr); $focus->description = EmailTemplate::parse_template($focus->description, $object_arr); $focus->description_html = EmailTemplate::parse_template($focus->description_html, $object_arr); } //if(!$focus->description)$focus->description=$temp_desc; //if(!$focus->description_html)$focus->description_html=$temp_desc; //echo $focus->description_html." ".$focus->description;die(); //// END TEMPLATE PARSING /////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////// //// PREP FOR ATTACHMENTS if(empty($focus->id)){ $focus->id = create_guid(); $focus->new_with_id = true; } //print_r($_POST);die(); /////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////// //// ATTACHMENT HANDLING $focus->handleAttachments(); /* var_dump($focus->parent_id); var_dump($focus->saved_attachments[0]->name); var_dump($focus->saved_attachments[0]->parent_name); */ //var_dump($focus->saved_attachments[0]->file); //die(); //foreach($user_attachment as $att) { $user_notes = $eedf->getAttachmentsNotes($user_attachment, $focus->name, $focus->module_dir, $focus->id); if(is_array($user_notes) && count($user_notes) > 0) foreach($user_notes as $un) $focus->saved_attachments[] = $un; /* require_once('modules/Notes/Note.php'); $n = new Note(); $n->name = $mod_strings['LBL_EMAIL_ATTACHMENT'].': '.$att[0]; $n->filename = $att[0]; $n->file_mime_type = 'application/pdf'; $n->parent_id = $focus->id; $n->parent_type = $focus->module_dir; $n->parent_name = $focus->name; $nid = $n->save(); var_dump($att[1]); die(); if(!copy($att[1], $sugar_config['upload_dir'].$nid)) { //$errors= error_get_last(); echo "COPY ERROR: ".$errors['type']; echo "
\n".$errors['message']; } */ //$focus->saved_attachments[] = $n; // } /* foreach($user_attachment as $att) { $user_notes = $eedf->getAttachmentNotes($focus->name, $focus->module_dir, $focus->id); require_once('modules/Notes/Note.php'); $n = new Note(); $n->name = $mod_strings['LBL_EMAIL_ATTACHMENT'].': '.$att[0]; $n->filename = $att[0]; $n->file_mime_type = 'application/pdf'; $n->parent_id = $focus->id; $n->parent_type = $focus->module_dir; $n->parent_name = $focus->name; $nid = $n->save(); var_dump($att[1]); die(); if(!copy($att[1], $sugar_config['upload_dir'].$nid)) { //$errors= error_get_last(); echo "COPY ERROR: ".$errors['type']; echo "
\n".$errors['message']; } $focus->saved_attachments[] = $n; } */ /* if(isset($_REQUEST['quote_id']) && $_REQUEST['quote_id'] != '') { require_once('modules/EcmQuotes/EcmQuote.php'); $off = new EcmQuote(); $off->retrieve($_REQUEST['quote_id']); $off->formatNumber(); if(isset($off->id) && $off->id != '') { require_once('modules/Notes/Note.php'); $n = new Note(); $n->name = $mod_strings['LBL_EMAIL_ATTACHMENT'].': '.$off->createPdfFileName(false); $n->filename = $off->createPdfFileName(); $n->file_mime_type = 'application/pdf'; $n->parent_id = $focus->id; $n->parent_type = $focus->module_dir; $n->parent_name = $focus->name; $nid = $n->save(); //var_dump($sugar_config['upload_dir'].'oferta.pdf'); die(); //echo $off->name; die(); //global $sugar_config; if($nid) $off->getPDF(null,'F',$sugar_config['upload_dir'].$nid); $focus->saved_attachments[] = $n; } $off->setTemplate(); $off->loadParser(); $focus->name = $off->template->mfp->parseText($focus->name); $focus->description = $off->template->mfp->parseText($focus->description); $focus->description_html = $off->template->mfp->parseText($focus->description_html); } */ //// END ATTACHMENT HANDLING /////////////////////////////////////////////////////////////////////////////// $focus->status = 'draft'; //echo '
';print_r($focus);echo '
'; $_REQUEST['send']=1; if($focus->type == 'archived' ) { $focus->status= 'archived'; } elseif(($focus->type == 'out' || $focus->type == 'forward')) { /////////////////////////////////////////////////////////////////////////// //// REPLY PROCESSING $old = array('<','>'); $new = array('<','>'); if($_REQUEST['from_addr'] != $_REQUEST['from_addr_name'].' <'.$_REQUEST['from_addr_email'].'>') { if(false === strpos($_REQUEST['from_addr'], '<')) { // we have an email only? $focus->from_addr = $_REQUEST['from_addr']; $focus->from_name = ''; } else { // we have a compound string $newFromAddr = str_replace($old, $new, $_REQUEST['from_addr']); $focus->from_addr = substr($newFromAddr, (1 + strpos($newFromAddr, '<')), (strpos($newFromAddr, '>') - strpos($newFromAddr, '<')) -1 ); $focus->from_name = substr($newFromAddr, 0, (strpos($newFromAddr, '<') -1)); } } elseif(!empty($_REQUEST['from_addr_email']) && isset($_REQUEST['from_addr_email'])) { $focus->from_addr = $_REQUEST['from_addr_email']; $focus->from_name = $_REQUEST['from_addr_name']; } else { $focus->from_addr = $focus->getSystemDefaultEmail(); //echo $focus->from_addr; } //// REPLY PROCESSING /////////////////////////////////////////////////////////////////////////// $expl=explode("<",$_REQUEST['from_addr']); $exppp=explode(">",$expl[1]); $focus->from_addr = trim($exppp[0]); $focus->from_name = trim($expl[0]); //echo "addr: (".$focus->from_addr.") name: (".$focus->from_name.") all: ".$_REQUEST['from_addr']; $focus->reply_to_addr=$focus->from_addr; if($focus->send()) { $focus->status = 'sent'; $eerr=$focus->ErrorInfo; } else { //echo "err"; $focus->status = 'send_error'; $eerr=$focus->ErrorInfo;echo $focus->ErrorInfo; } //echo $eerr;die(); } // delete the existing relationship of all the email addresses with this email $query = "update emails_email_addr_rel set deleted = 1 WHERE email_id = '{$focus->id}'"; $focus->db->query($query); // delete al the relationship of this email with all the beans $query = "update emails_beans set deleted = 1, bean_id = '', bean_module = '' WHERE email_id = '{$focus->id}'"; $focus->db->query($query); //relations add// if(count($acc)>0){ foreach($acc as $key=>$value){ $GLOBALS['db']->query("insert into emails_beans(id,email_id,bean_id,bean_module,date_modified,deleted) values('".create_guid()."','".$focus->id."','".$key."','Accounts','".date("Y-m-d H:i:s")."','0')"); } } if(count($cnt)>0){ foreach($cnt as $key=>$value){ $GLOBALS['db']->query("insert into emails_beans(id,email_id,bean_id,bean_module,date_modified,deleted) values('".create_guid()."','".$focus->id."','".$key."','Contacts','".date("Y-m-d H:i:s")."','0')"); } } if(count($ac)>0){ foreach($ac as $key=>$value){ $GLOBALS['db']->query("insert into emails_beans(id,email_id,bean_id,bean_module,date_modified,deleted) values('".create_guid()."','".$focus->id."','".$key."','Accounts','".date("Y-m-d H:i:s")."','0')"); } } /////////////////////////////// if(isset($_REQUEST['object_type']) && !empty($_REQUEST['object_type']) && isset($_REQUEST['object_id']) && !empty($_REQUEST['object_id'])) { //run linking code only if the object_id has not been linked as part of the contacts above $GLOBALS['log']->debug("CESELY".$_REQUEST['object_type']); if(!in_array($_REQUEST['object_id'],$exContactIds)){ $rel = strtolower($_REQUEST['object_type']); $focus->load_relationship($rel); $focus->$rel->add($_REQUEST['object_id']); $GLOBALS['log']->debug("CESELY LOADED".$_REQUEST['object_type']); } } //// handle legacy parent_id/parent_type relationship calls elseif(isset($_REQUEST['parent_type']) && !empty($_REQUEST['parent_type']) && isset($_REQUEST['parent_id']) && !empty($_REQUEST['parent_id'])) { //run linking code only if the object_id has not been linked as part of the contacts above if(!isset($exContactIds) || !in_array($_REQUEST['parent_id'],$exContactIds)){ $rel = strtolower($_REQUEST['parent_type']); $focus->load_relationship($rel); $focus->$rel->add($_REQUEST['parent_id']); } } //// END RELATIONSHIP LINKING /////////////////////////////////////////////////////////////////////////////// // If came from email archiving edit view, this would have been set from form input. if (!isset($focus->date_start)) { $today = gmdate('Y-m-d H:i:s'); $focus->date_start = $timedate->to_display_date($today); $focus->time_start = $timedate->to_display_time($today, true); } $focus->date_sent = ""; $focus->save(false); $GLOBALS['db']->query("update emails_text set from_addr='".$_REQUEST['from_addr']."',to_addrs='".$_REQUEST['to_addrs']."' where email_id='".$focus->id."'"); //// END EMAIL SAVE/SEND SETUP /////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////// //// RELATIONSHIP LINKING if(isset($data)) { $eedf->saveEmailRelationToAssignedIds($focus->id); } $focus->load_relationship('users'); $focus->users->add($current_user->id); if(!empty($_REQUEST['to_addrs_ids'])) { $focus->load_relationship('contacts'); $exContactIds = explode(';', $_REQUEST['to_addrs_ids']); foreach($exContactIds as $contactId) { $contactId = trim($contactId); $focus->contacts->add($contactId); } } $out1 = ob_get_contents(); ob_end_clean(); if(isset($_REQUEST['to_pdf']) && ($_REQUEST['to_pdf'] == '1' || $_REQUEST['to_pdf'] == 'true')) { echo ' '; die(); } //header("Location: index.php?action=EditView&module=EcmEmails".((isset($_REQUEST['to_pdf']) && ($_REQUEST['to_pdf'] == '1' || $_REQUEST['to_pdf'] == 'true'))?'&to_pdf=1':'')); die(); echo "Email Wyslany!"; echo $focus->status; die(); /////////////////////////////////////////////////////////////////////////////// //// PAGE REDIRECTION /////////////////////////////////////////////////////////////////////////////// $return_id = $focus->id; if(empty($_POST['return_module'])) { $return_module = "EcmEmails"; } else { $return_module = $_POST['return_module']; } if(empty($_POST['return_action'])) { $return_action = "DetailView"; } else { $return_action = $_POST['return_action']; } $GLOBALS['log']->debug("Saved record with id of ".$return_id); require_once('include/formbase.php'); if($focus->type == 'draft') { if($return_module == 'EcmEmails') { header("Location: index.php?module=$return_module&action=ListViewDrafts"); } else { handleRedirect($return_id, 'EcmEmails'); } } elseif($focus->type == 'out') { if($return_module == 'Home') { header('Location: index.php?module='.$return_module.'&action=index'); } if(!empty($_REQUEST['return_id'])) { $return_id = $_REQUEST['return_id']; } header('Location: index.php?action='.$return_action.'&module='.$return_module.'&record='.$return_id.'&assigned_user_id='.$current_user->id.'&type=inbound'); } elseif(isset($_POST['return_id']) && $_POST['return_id'] != "") { $return_id = $_POST['return_id']; } header("Location: index.php?action=$return_action&module=$return_module&record=$return_id"); ?>