167 lines
4.0 KiB
PHP
Executable File
167 lines
4.0 KiB
PHP
Executable File
<?php
|
|
require_once 'defaults.php';
|
|
require_once INCLUDES_DIR . 'includes.php';
|
|
|
|
// contact form fields
|
|
$contactform_inputs = array(
|
|
'name',
|
|
'email',
|
|
'url',
|
|
'content'
|
|
);
|
|
|
|
// Validates the POST data
|
|
function contact_validate() {
|
|
global $smarty, $contactform_inputs, $lang;
|
|
|
|
$lerr = & $lang ['contact'] ['error'];
|
|
|
|
$r = true;
|
|
|
|
$name = trim(htmlspecialchars(@$_POST ['name']));
|
|
$email = isset($_POST ['email']) ? trim(htmlspecialchars($_POST ['email'])) : null;
|
|
$url = isset($_POST ['url']) ? trim(stripslashes(htmlspecialchars($_POST ['url']))) : null;
|
|
$content = isset($_POST ['content']) ? trim(addslashes($_POST ['content'])) : null;
|
|
|
|
$errors = array();
|
|
|
|
// if the request does not contain all input fields, it might be forged
|
|
foreach ($contactform_inputs as $input) {
|
|
if (!array_key_exists($input, $_POST)) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// check name
|
|
if (!$name) {
|
|
$errors ['name'] = $lerr ['name'];
|
|
}
|
|
|
|
// check email
|
|
if ($email) {
|
|
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
|
|
$errors ['email'] = $lerr ['email'];
|
|
}
|
|
}
|
|
|
|
// check url
|
|
if ($url) {
|
|
if (!filter_var($url, FILTER_VALIDATE_URL)) {
|
|
$errors ['url'] = $lerr ['www'];
|
|
}
|
|
}
|
|
|
|
// check content
|
|
if (!$content) {
|
|
$errors ['content'] = $lerr ['content'];
|
|
}
|
|
|
|
// assign error messages to template
|
|
if ($errors) {
|
|
$smarty->assign('error', $errors);
|
|
return false;
|
|
}
|
|
|
|
$arr ['version'] = system_ver();
|
|
$arr ['name'] = $name;
|
|
|
|
if ($email) {
|
|
($arr ['email'] = $email);
|
|
}
|
|
|
|
if ($url) {
|
|
($arr ['url'] = ($url));
|
|
}
|
|
|
|
$arr ['content'] = $content;
|
|
|
|
if ($v = utils_ipget()) {
|
|
$arr ['ip-address'] = $v;
|
|
}
|
|
|
|
// check aaspam if active
|
|
if (apply_filters('comment_validate', true, $arr))
|
|
return $arr;
|
|
else
|
|
return false;
|
|
}
|
|
|
|
function contactform() {
|
|
global $smarty, $lang, $fp_config, $contactform_inputs;
|
|
|
|
// initial call of the contact form
|
|
if (empty($_POST)) {
|
|
$smarty->assign('success', system_geterr('contact'));
|
|
$smarty->assignByRef('panelstrings', $lang ['contact']);
|
|
return;
|
|
}
|
|
|
|
// new form, we (re)set the session data
|
|
utils_nocache_headers();
|
|
|
|
$validationResult = contact_validate();
|
|
|
|
// if validation failed
|
|
if ($validationResult === false) {
|
|
// assign given input values to the template, so they're prefilled again
|
|
$smarty->assign('values', $_POST);
|
|
return;
|
|
}
|
|
|
|
// add https to url if not given
|
|
if (!empty($_POST ['url']) && strpos($_POST ['url'], 'http://') === false && strpos($_POST ['url'], 'https://') === false) {
|
|
$_POST ['url'] = 'https://' . $_POST ['url'];
|
|
}
|
|
|
|
// okay, validation returned validated values
|
|
// now build the mail content
|
|
$msg = "{$lang['contact']['notification']['name']} \n{$validationResult['name']}\n\n";
|
|
|
|
if (isset($validationResult ['email'])) {
|
|
$msg .= "{$lang['contact']['notification']['email']} \n{$validationResult['email']}\n\n";
|
|
}
|
|
if (isset($validationResult ['url'])) {
|
|
$msg .= "{$lang['contact']['notification']['www']} \n{$validationResult['url']}\n\n";
|
|
}
|
|
$msg .= "{$lang['contact']['notification']['content']} \n{$validationResult['content']}\n";
|
|
|
|
// send notification mail to site admin
|
|
// for non-ASCII characters in the e-mail header use RFC 1342 — Encodes $subject with MIME base64 via core.utils.php
|
|
$success = @utils_mail((isset($validationResult ['email']) ? $validationResult ['email'] : $fp_config ['general'] ['email']), "{$lang['contact']['notification']['subject']} {$fp_config['general']['title']}", $msg);
|
|
system_seterr('contact', $success ? 1 : -1);
|
|
utils_redirect(basename(__FILE__));
|
|
}
|
|
|
|
function contact_main() {
|
|
global $smarty;
|
|
|
|
// Initialize modifier functions
|
|
$smarty->registerPlugin('modifier', 'stripslashes', 'stripslashes');
|
|
$smarty->registerPlugin('modifier', 'wp_specialchars', 'wp_specialchars');
|
|
|
|
$lang = lang_load('contact');
|
|
|
|
$smarty->assign('subject', $lang ['contact'] ['head']);
|
|
$smarty->assign('content', 'shared:contact.tpl');
|
|
contactform();
|
|
}
|
|
|
|
|
|
function contact_display() {
|
|
global $smarty;
|
|
|
|
contact_main();
|
|
|
|
theme_init($smarty);
|
|
|
|
$smarty->display('default.tpl');
|
|
|
|
unset($smarty);
|
|
|
|
do_action('shutdown');
|
|
}
|
|
|
|
system_init();
|
|
contact_display();
|
|
?>
|