Marius Cramer
2015-08-06 37b29231e47a0c4458dc1c15d98588f16f07e1e2
commit | author | age
45f11e 1 <?php
T 2 /*
89623d 3 Copyright (c) 2005 - 2009, Till Brehm, projektfarm Gmbh
45f11e 4 All rights reserved.
T 5
6 Redistribution and use in source and binary forms, with or without modification,
7 are permitted provided that the following conditions are met:
8
9     * Redistributions of source code must retain the above copyright notice,
10       this list of conditions and the following disclaimer.
11     * Redistributions in binary form must reproduce the above copyright notice,
12       this list of conditions and the following disclaimer in the documentation
13       and/or other materials provided with the distribution.
14     * Neither the name of ISPConfig nor the names of its contributors
15       may be used to endorse or promote products derived from this software without
16       specific prior written permission.
17
18 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
19 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
22 INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
23 BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
25 OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
27 EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30
31 /******************************************
32 * Begin Form configuration
33 ******************************************/
34
35 $tform_def_file = "form/mail_forward.tform.php";
36
37 /******************************************
38 * End Form configuration
39 ******************************************/
40
7fe908 41 require_once '../../lib/config.inc.php';
MC 42 require_once '../../lib/app.inc.php';
45f11e 43
910093 44 //* Check permissions for module
T 45 $app->auth->check_module_permissions('mail');
45f11e 46
T 47 // Loading classes
48 $app->uses('tpl,tform,tform_actions');
49 $app->load('tform_actions');
50
51 class page_action extends tform_actions {
7fe908 52
965795 53     function onShowNew() {
T 54         global $app, $conf;
7fe908 55
965795 56         // we will check only users, not admins
T 57         if($_SESSION["s"]["user"]["typ"] == 'user') {
7fe908 58             if(!$app->tform->checkClientLimit('limit_mailforward', "type = 'forward'")) {
3cebc3 59                 $app->error($app->tform->wordbook["limit_mailforward_txt"]);
T 60             }
7fe908 61             if(!$app->tform->checkResellerLimit('limit_mailforward', "type = 'forward'")) {
3cebc3 62                 $app->error('Reseller: '.$app->tform->wordbook["limit_mailforward_txt"]);
965795 63             }
T 64         }
7fe908 65
965795 66         parent::onShowNew();
T 67     }
7fe908 68
45f11e 69     function onShowEnd() {
T 70         global $app, $conf;
7fe908 71
45f11e 72         $email = $this->dataRecord["source"];
7fe908 73         $email_parts = explode("@", $email);
MC 74         $app->tpl->setVar("email_local_part", $email_parts[0]);
d6363b 75         $email_parts[1] = $app->functions->idn_decode($email_parts[1]);
7fe908 76
45f11e 77         // Getting Domains of the user
02bf99 78         //$sql = "SELECT domain FROM mail_domain WHERE ".$app->tform->getAuthSQL('r').' ORDER BY domain';
T 79         $sql = "SELECT domain FROM mail_domain WHERE domain NOT IN (SELECT SUBSTR(source,2) FROM mail_forwarding WHERE type = 'aliasdomain') AND ".$app->tform->getAuthSQL('r')." ORDER BY domain";
45f11e 80         $domains = $app->db->queryAllRecords($sql);
T 81         $domain_select = '';
82         foreach( $domains as $domain) {
7fe908 83             $domain['domain'] = $app->functions->idn_decode($domain['domain']);
d4d985 84             $selected = (isset($email_parts[1]) && $domain["domain"] == $email_parts[1])?'SELECTED':'';
45f11e 85             $domain_select .= "<option value='$domain[domain]' $selected>$domain[domain]</option>\r\n";
T 86         }
7fe908 87         $app->tpl->setVar("email_domain", $domain_select);
MC 88
45f11e 89         parent::onShowEnd();
T 90     }
7fe908 91
45f11e 92     function onSubmit() {
T 93         global $app, $conf;
7fe908 94
45f11e 95         // Check if Domain belongs to user
2af58c 96         $domain = $app->db->queryOneRecord("SELECT server_id, domain FROM mail_domain WHERE domain = ? AND ".$app->tform->getAuthSQL('r'), $app->functions->idn_encode($_POST["email_domain"]));
d6363b 97         if($domain["domain"] != $app->functions->idn_encode($_POST["email_domain"])) $app->tform->errorMessage .= $app->tform->wordbook["no_domain_perm"];
7fe908 98
965795 99         // Check the client limits, if user is not the admin
T 100         if($_SESSION["s"]["user"]["typ"] != 'admin') { // if user is not admin
101             // Get the limits of the client
604c0c 102             $client_group_id = $app->functions->intval($_SESSION["s"]["user"]["default_group"]);
cc7a82 103             $client = $app->db->queryOneRecord("SELECT limit_mailforward FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = ?", $client_group_id);
965795 104
T 105             // Check if the user may add another mailbox.
106             if($this->id == 0 && $client["limit_mailforward"] >= 0) {
2af58c 107                 $tmp = $app->db->queryOneRecord("SELECT count(forwarding_id) as number FROM mail_forwarding WHERE sys_groupid = ? AND type = 'forward'", $client_group_id);
965795 108                 if($tmp["number"] >= $client["limit_mailforward"]) {
T 109                     $app->tform->errorMessage .= $app->tform->wordbook["limit_mailforward_txt"]."<br>";
110                 }
111                 unset($tmp);
112             }
113         } // end if user is not admin
7fe908 114
45f11e 115         // compose the email field
d6363b 116         $this->dataRecord["source"] = $_POST["email_local_part"]."@".$app->functions->idn_encode($_POST["email_domain"]);
45f11e 117         // Set the server id of the mailbox = server ID of mail domain.
T 118         $this->dataRecord["server_id"] = $domain["server_id"];
7fe908 119
45f11e 120         unset($this->dataRecord["email_local_part"]);
T 121         unset($this->dataRecord["email_domain"]);
7fe908 122
7acef0 123         //* Check if there is no active mailbox with this address
2af58c 124         $tmp = $app->db->queryOneRecord("SELECT count(mailuser_id) as number FROM mail_user WHERE postfix = 'y' AND email = ?", $this->dataRecord["source"]);
89623d 125         if($tmp['number'] > 0) $app->tform->errorMessage .= $app->tform->lng("duplicate_mailbox_txt")."<br>";
T 126         unset($tmp);
7fe908 127
45f11e 128         parent::onSubmit();
T 129     }
7fe908 130
d4d985 131     function onAfterInsert() {
T 132         global $app;
7fe908 133
a6e3ae 134         $domain = $app->db->queryOneRecord("SELECT sys_groupid FROM mail_domain WHERE domain = ? AND ".$app->tform->getAuthSQL('r'), $app->functions->idn_encode($_POST["email_domain"]));
2af58c 135         $app->db->query("update mail_forwarding SET sys_groupid = ? WHERE forwarding_id = ?", $domain['sys_groupid'], $this->id);
7fe908 136
d4d985 137     }
7fe908 138
45f11e 139 }
T 140
141 $page = new page_action;
142 $page->onLoad();
143
7fe908 144 ?>