Fix for #55: HTTPS URLs in the contact form are now handled correctly.

This commit is contained in:
azett 2020-01-01 00:48:46 +01:00
parent ddc2af887b
commit eb20caebc5

View File

@ -1,40 +1,33 @@
<?php
require_once 'defaults.php';
require_once (INCLUDES_DIR.'includes.php');
require SMARTY_DIR . 'SmartyValidate.class.php';
require_once 'defaults.php';
require_once (INCLUDES_DIR . 'includes.php');
require SMARTY_DIR . 'SmartyValidate.class.php';
function contact_form_validate() {
$arr ['version'] = system_ver();
$arr ['name'] = $_POST ['name'];
function contact_form_validate() {
if (!empty($_POST ['email']))
($arr ['email'] = $_POST ['email']);
if (!empty($_POST ['url']))
($arr ['url'] = $_POST ['url']);
$arr ['content'] = $_POST ['content'];
$arr['version'] = system_ver();
$arr['name'] = $_POST['name'];
if (!empty($_POST['email']))
($arr['email'] = $_POST['email']);
if (!empty($_POST['url']))
($arr['url'] = $_POST['url']);
$arr['content'] = $_POST['content'];
$arr['ip-address'] = utils_ipget();
$arr ['ip-address'] = utils_ipget();
if (apply_filters('comment_validate', true, $arr))
return $arr;
else return false;
}
function contact_form() {
else
return false;
}
function contact_form() {
global $smarty, $lang, $fp_config;
if(empty($_POST)) {
if (empty($_POST)) {
$smarty->assign('success', system_geterr('contact'));
$smarty->assign_by_ref('panelstrings', $lang['contact']);
$smarty->assign_by_ref('panelstrings', $lang ['contact']);
// new form, we (re)set the session data
SmartyValidate::connect($smarty, true);
@ -48,51 +41,43 @@
// validate after a POST
SmartyValidate::connect($smarty);
if (!empty($_POST['url']) && strpos($_POST['url'], 'http://')===false) $_POST['url'] = 'http://'.$_POST['url'];
// add http to url if not given
if (!empty($_POST ['url']) && strpos($_POST ['url'], 'http://') === false && strpos($_POST ['url'], 'https://') === false)
$_POST ['url'] = 'http://' . $_POST ['url'];
// custom hook here!!
// we'll use comment actions, anyway
if(SmartyValidate::is_valid($_POST) && $arr=contact_form_validate()) {
if (SmartyValidate::is_valid($_POST) && $arr = contact_form_validate()) {
$msg = "Name: \n{$arr['name']} \n\n";
if (isset($arr['email']))
if (isset($arr ['email']))
$msg .= "Email: {$arr['email']}\n\n";
if (isset($arr['url']))
if (isset($arr ['url']))
$msg .= "WWW: {$arr['url']}\n\n";
$msg .= "Content:\n{$arr['content']}\n";
$success = @utils_mail(
(
isset($arr['email'])?
$arr['email']
:
$fp_config['general']['email']
),
"Contact sent through {$fp_config['general']['title']} ", $msg );
$success = @utils_mail((isset($arr ['email']) ? $arr ['email'] : $fp_config ['general'] ['email']), "Contact sent through {$fp_config['general']['title']} ", $msg);
system_seterr('contact', $success? 1 : -1);
system_seterr('contact', $success ? 1 : -1);
utils_redirect(basename(__FILE__));
} else {
$smarty->assign('values', $_POST);
}
}
}
}
function contact_main() {
function contact_main() {
global $smarty;
$lang = lang_load('contact');
$smarty->assign('subject', $lang['contact']['head']);
$smarty->assign('subject', $lang ['contact'] ['head']);
$smarty->assign('content', 'shared:contact.tpl');
contact_form();
}
}
function contact_display() {
function contact_display() {
global $smarty;
contact_main();
@ -104,11 +89,9 @@
unset($smarty);
do_action('shutdown');
}
}
system_init();
contact_display();
system_init();
contact_display();
?>