2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4 * SugarCRM Community Edition is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
7 * This program is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU Affero General Public License version 3 as published by the
9 * Free Software Foundation with the addition of the following permission added
10 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
14 * This program is distributed in the hope that it will be useful, but WITHOUT
15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
19 * You should have received a copy of the GNU Affero General Public License along with
20 * this program; if not, see http://www.gnu.org/licenses or write to the Free
21 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
24 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
27 * The interactive user interfaces in modified source and object code versions
28 * of this program must display Appropriate Legal Notices, as required under
29 * Section 5 of the GNU Affero General Public License version 3.
31 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32 * these Appropriate Legal Notices must retain the display of the "Powered by
33 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34 * technical reasons, the Appropriate Legal Notices must display the words
35 * "Powered by SugarCRM".
36 ********************************************************************************/
38 /*********************************************************************************
40 * Description: TODO: To be written.
41 * Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.
42 * All Rights Reserved.
43 * Contributor(s): ______________________________________..
44 ********************************************************************************/
46 if(!isset($_REQUEST['record']))
47 sugar_die("A record number must be specified to delete the campaign.");
51 $focus = new Campaign();
52 $focus->retrieve($_REQUEST['record']);
54 if (isset($_REQUEST['mode']) and $_REQUEST['mode']=='Test') {
55 //deletes all data associated with the test run.
57 //delete from emails table.
58 if ($focus->db->dbType=='mysql') {
60 $query="update emails ";
61 $query.="inner join campaign_log on campaign_log.related_id = emails.id and campaign_log.campaign_id = '{$focus->id}' ";
62 $query.="inner join prospect_lists on campaign_log.list_id = prospect_lists.id and prospect_lists.list_type='test' ";
63 $query.="set emails.deleted=1 ";
64 } elseif ($focus->db->dbType=='mssql') {
65 $query="update emails ";
66 $query.="set emails.deleted=1 ";
67 $query.="where id in ( ";
68 $query.="select related_id from campaign_log ";
69 $query.="inner join prospect_lists on campaign_log.list_id = prospect_lists.id ";
70 $query.="and prospect_lists.list_type='test' ";
71 $query.="and campaign_log.campaign_id = '{$focus->id}' ) ";
74 $focus->db->query($query);
76 //delete from message queue.
77 if ($focus->db->dbType=='mysql') {
78 $query="delete emailman.* from emailman ";
79 $query.="inner join prospect_lists on emailman.list_id = prospect_lists.id and prospect_lists.list_type='test' ";
80 $query.="WHERE emailman.campaign_id = '{$focus->id}' ";
81 } elseif ($focus->db->dbType=='mssql') {
82 $query="delete from emailman ";
83 $query.="where list_id in ( ";
84 $query.=" select prospect_list_id from prospect_list_campaigns ";
85 $query.=" inner join prospect_lists on prospect_list_campaigns.prospect_list_id = prospect_lists.id ";
86 $query.=" where prospect_lists.list_type='test' and prospect_list_campaigns.campaign_id = '{$focus->id}' ) ";
89 $focus->db->query($query);
91 //delete from campaign_log
92 if ($focus->db->dbType=='mysql') {
93 $query="update campaign_log ";
94 $query.="inner join prospect_lists on campaign_log.list_id = prospect_lists.id and prospect_lists.list_type='test' ";
95 $query.="set campaign_log.deleted=1 ";
96 $query.="where campaign_log.campaign_id='{$focus->id}' ";
97 } elseif ($focus->db->dbType=='mssql') {
98 $query="update campaign_log ";
99 $query.="set campaign_log.deleted=1 ";
100 $query.="where list_id in ( ";
101 $query.=" select id from prospect_lists ";
102 $query.=" where prospect_lists.list_type='test') ";
103 $query.="and campaign_log.campaign_id='{$focus->id}' ";
106 $focus->db->query($query);
108 if(!$focus->ACLAccess('Delete')){
109 ACLController::displayNoAccess(true);
112 $focus->mark_deleted($_REQUEST['record']);
114 $return_id=!empty($_REQUEST['return_id'])?$_REQUEST['return_id']:$focus->id;
115 header("Location: index.php?module=".$_REQUEST['return_module']."&action=".$_REQUEST['return_action']."&record=".$return_id);