1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-17 20:58:30 +01:00
php-e107/contact.php

178 lines
4.4 KiB
PHP
Raw Normal View History

2006-12-02 04:36:16 +00:00
<?php
/*
+ ----------------------------------------------------------------------------+
| e107 website system
|
2009-11-18 01:06:08 +00:00
| Copyright (C) 2008-2009 e107 Inc
2006-12-02 04:36:16 +00:00
| http://e107.org
2009-07-14 05:31:57 +00:00
|
2006-12-02 04:36:16 +00:00
|
| Released under the terms and conditions of the
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/contact.php,v $
2010-02-10 18:18:01 +00:00
| $Revision$
| $Date$
| $Author$
2006-12-02 04:36:16 +00:00
+----------------------------------------------------------------------------+
*/
require_once("class2.php");
2009-08-28 15:30:25 +00:00
// security image may be disabled by removing the appropriate shortcodes from the template.
require_once(e_HANDLER."secure_img_handler.php");
$sec_img = new secure_image;
include_lan(e_LANGUAGEDIR.e_LANGUAGE.'/lan_'.e_PAGE);
2006-12-02 04:36:16 +00:00
require_once(HEADERF);
if (!$CONTACT_FORM) {
if (file_exists(THEME."contact_template.php")) {
require_once(THEME."contact_template.php");
2010-07-27 10:25:17 +00:00
}
else
{
// Redirect Page if no contact-form or contact-info is available.
if(($pref['sitecontacts']== e_UC_NOBODY) && trim(SITECONTACTINFO) == "")
{
e107::getRedirect()->redirect(e_BASE."index.php");
exit;
}
2006-12-02 04:36:16 +00:00
require_once(e_THEME."templates/contact_template.php");
}
}
2012-06-20 01:12:33 +00:00
if(isset($_POST['send-contactus']))
{
2006-12-02 04:36:16 +00:00
$error = "";
2009-12-10 21:03:56 +00:00
$sender_name = $tp->toEmail($_POST['author_name'],TRUE,'RAWTEXT');
2006-12-02 04:36:16 +00:00
$sender = check_email($_POST['email_send']);
2009-12-10 21:03:56 +00:00
$subject = $tp->toEmail($_POST['subject'],TRUE,'RAWTEXT');
$body = $tp->toEmail($_POST['body'],TRUE,'RAWTEXT');
2006-12-02 04:36:16 +00:00
// Check Image-Code
if (isset($_POST['rand_num']) && !$sec_img->verify_code($_POST['rand_num'], $_POST['code_verify']))
{
$error .= LANCONTACT_15."\\n";
}
// Check message body.
if(strlen(trim($_POST['body'])) < 15)
{
$error .= LANCONTACT_12."\\n";
}
// Check subject line.
if(strlen(trim($_POST['subject'])) < 2)
{
$error .= LANCONTACT_13."\\n";
}
if(!strpos(trim($_POST['email_send']),"@"))
{
$error .= LANCONTACT_11."\\n";
}
2006-12-02 04:36:16 +00:00
// Check email address on remote server (if enabled).
2009-12-10 21:03:56 +00:00
if ($pref['signup_remote_emailcheck'] && $error == '')
2006-12-02 04:36:16 +00:00
{
require_once(e_HANDLER."mail_validation_class.php");
2010-10-28 20:17:40 +00:00
list($adminuser,$adminhost) = explode('@', SITEADMINEMAIL, 2);
2006-12-02 04:36:16 +00:00
$validator = new email_validation_class;
$validator->localuser= $adminuser;
$validator->localhost= $adminhost;
$validator->timeout=3;
// $validator->debug=1;
// $validator->html_debug=1;
if($validator->ValidateEmailBox($sender) != 1)
{
$error .= LANCONTACT_11."\\n";
}
}
// No errors - so proceed to email the admin and the user (if selected).
if(!$error)
{
$body .= "\n\nIP:\t".USERIP."\n";
if (USER)
{
2006-12-02 04:36:16 +00:00
$body .= "User:\t#".USERID." ".USERNAME."\n";
}
2006-12-02 04:36:16 +00:00
if(!$_POST['contact_person'] && isset($pref['sitecontacts'])) // only 1 person, so contact_person not posted.
{
if($pref['sitecontacts'] == e_UC_MAINADMIN)
{
$query = "user_perms = '0' OR user_perms = '0.' ";
}
elseif($pref['sitecontacts'] == e_UC_ADMIN)
{
$query = "user_admin = 1 ";
}
else
{
$query = "FIND_IN_SET(".$pref['sitecontacts'].",user_class) ";
2006-12-02 04:36:16 +00:00
}
}
else
{
$query = "user_id = ".intval($_POST['contact_person']);
2006-12-02 04:36:16 +00:00
}
if($sql -> db_Select("user", "user_name,user_email",$query." LIMIT 1"))
{
$row = $sql -> db_Fetch();
$send_to = $row['user_email'];
$send_to_name = $row['user_name'];
}
else
{
$send_to = SITEADMINEMAIL;
$send_to_name = ADMIN;
}
require_once(e_HANDLER."mail.php");
$message = (sendemail($send_to,"[".SITENAME."] ".$subject, $body,$send_to_name,$sender,$sender_name)) ? LANCONTACT_09 : LANCONTACT_10;
if(isset($pref['contact_emailcopy']) && $pref['contact_emailcopy'] && $_POST['email_copy'] == 1){
sendemail($sender,"[".SITENAME."] ".$subject, $body,ADMIN,$sender,$sender_name);
}
$ns -> tablerender('', $message);
require_once(FOOTERF);
exit;
}
else
{
require_once(e_HANDLER."message_handler.php");
message_handler("P_ALERT", $error);
}
}
if(SITECONTACTINFO && $CONTACT_INFO)
{
$text = $tp->parseTemplate($CONTACT_INFO, TRUE, $contact_shortcodes);
2006-12-02 04:36:16 +00:00
$ns -> tablerender(LANCONTACT_01, $text,"contact");
}
if(isset($pref['sitecontacts']) && $pref['sitecontacts'] != 255)
{
2012-06-20 01:12:33 +00:00
// require_once(e_CORE."shortcodes/batch/contact_shortcodes.php");
$contact_shortcodes = e107::getScBatch('contact');
2006-12-02 04:36:16 +00:00
$text = $tp->parseTemplate($CONTACT_FORM, TRUE, $contact_shortcodes);
if(trim($text) != "")
{
$ns -> tablerender(LANCONTACT_02, $text, "contact");
}
}
require_once(FOOTERF);
exit;
?>