Project

General

Profile

« Previous | Next » 

Revision 605

Added by thorn about 17 years ago

fixed some issues with CAPTCHA and ASP: Adjusted baseline of '*' in supplyed fonts to meet baseline of numbers. Added counter to ttf_image generation-loop. Removed now unneeded GD-lib checks. Improved ASP in news-module.

View differences:

trunk/CHANGELOG
17 17
26-Jan-2008 Matthias Gallas
18 18
+	Added keywords to files where they are missing
19 19
26-Jan-2008 Thomas Hornik
20
!	fixed some issues with CAPTCHA and ASP. Adjusted baseline of '*' in supplyed fonts to meet
21
	baseline of numbers. Added counter to ttf_image generation-loop. Removed now unneeded GD-lib verification.
22
	Improved ASP in news-module.
20 23
+	module news: added publish_until field to control the visibility of a news-posting by date and time
21 24
!	added strongly "condensed" fonts with many intersections for ttf-CAPTCHA as default fonts.
22 25
	It should be very difficult for spam-bots to recognize intersected characters.
trunk/wb/include/captcha/captchas/ttf_image.php
58 58

  
59 59
// create image
60 60
$image_failed = true;
61
$i=0;
61 62
do {
62 63
	$image = ImageCreateFromPNG($bg); // backgroundimage
63 64
	$grey = rand(0,50);
......
76 77
	) {
77 78
		$image_failed = false;
78 79
	}
80
	if(++$i > 5) // too many tries! Use the image
81
		break;
79 82
} while($image_failed);
80 83

  
81 84
captcha_header();
trunk/wb/modules/form/modify_settings.php
77 77
	<tr>
78 78
		<td colspan="2"><strong><?php echo $HEADING['GENERAL_SETTINGS']; ?></strong></td>
79 79
	</tr>
80
	<?php if(extension_loaded('gd') AND function_exists('imageCreateFromJpeg')) { /* Make's sure GD library is installed */ ?>
81 80
	<tr>
82 81
		<td class="setting_name" width="30%"><?php echo $TEXT['CAPTCHA_VERIFICATION']; ?>:</td>
83 82
		<td>
......
87 86
			<label for="use_captcha_false"><?php echo $TEXT['DISABLED']; ?></label>
88 87
		</td>
89 88
	</tr>
90
	<?php } ?>
91 89
	<tr>
92 90
		<td class="setting_name" width="30%"><?php echo $TEXT['MAX_SUBMISSIONS_PER_HOUR']; ?>:</td>
93 91
		<td class="setting_name">
trunk/wb/modules/form/save_settings.php
41 41
$field_loop = $admin->add_slashes($_POST['field_loop']);
42 42
$footer = $admin->add_slashes($_POST['footer']);
43 43
$email_to = $admin->add_slashes($_POST['email_to']);
44
if(extension_loaded('gd') AND function_exists('imageCreateFromJpeg')) {
45
	$use_captcha = $_POST['use_captcha'];
46
} else {
47
	$use_captcha = false;
48
}
44
$use_captcha = $_POST['use_captcha'];
49 45
if($_POST['email_from_field'] == '') {
50 46
	$email_from = $admin->add_slashes($_POST['email_from']);
51 47
} else {
trunk/wb/modules/form/add.php
48 48
$success_email_subject = 'You have submitted a form';
49 49
$max_submissions = 50;
50 50
$stored_submissions = 50;
51
if(extension_loaded('gd') AND function_exists('imageCreateFromJpeg')) { /* Make's sure GD library is installed */
52
	$use_captcha = true;
53
} else {
54
	$use_captcha = false;
55
}
51
$use_captcha = true;
56 52
$database->query("INSERT INTO ".TABLE_PREFIX."mod_form_settings (page_id,section_id,header,field_loop,footer,email_to,email_from,email_subject,success_page,success_email_to,success_email_from,success_email_text,success_email_subject,max_submissions,stored_submissions,use_captcha) VALUES ('$page_id','$section_id','$header','$field_loop','$footer','$email_to','$email_from','$email_subject','$success_page','$success_email_to','$success_email_from','$success_email_text','$success_email_subject','$max_submissions','$stored_submissions','$use_captcha')");
57 53

  
58 54
?>
trunk/wb/modules/news/modify_settings.php
130 130
				</select>
131 131
			</td>
132 132
		</tr>
133
		<?php if(extension_loaded('gd') AND function_exists('imageCreateFromJpeg')) { /* Make's sure GD library is installed */ ?>
134 133
		<tr>
135 134
			<td class="setting_name"><?php echo $TEXT['CAPTCHA_VERIFICATION']; ?>:</td>
136 135
			<td>
......
140 139
				<label for="use_captcha_false"><?php echo $TEXT['DISABLED']; ?></label>
141 140
			</td>
142 141
		</tr>
142
		<?php if(extension_loaded('gd') AND function_exists('imageCreateFromJpeg')) { /* Make's sure GD library is installed */ ?>
143 143
		<tr>
144 144
			<td>
145 145
				<?php echo $TEXT['RESIZE_IMAGE_TO']; ?>:
trunk/wb/modules/news/view.php
341 341
		
342 342
		// Print comments footer
343 343
		echo str_replace('[ADD_COMMENT_URL]', WB_URL.'/modules/news/comment.php?id='.POST_ID.'&sid='.$section_id, $setting_comments_footer);
344
		
345
		if(ENABLED_ASP) {
346
			$_SESSION['comes_from_view'] = true;
347
			$_SESSION['comes_from_view_time'] = time();
348
		}
349 344
	}
350
		
345
	if(ENABLED_ASP) {
346
		$_SESSION['comes_from_view'] = POST_ID;
347
		$_SESSION['comes_from_view_time'] = time();
348
	}
351 349
}
352 350

  
353 351
?>
trunk/wb/modules/news/save_settings.php
43 43
$comments_page = $admin->add_slashes(str_replace($friendly, $raw, $_POST['comments_page']));
44 44
$commenting = $_POST['commenting'];
45 45
$posts_per_page = $_POST['posts_per_page'];
46
$use_captcha = $_POST['use_captcha'];
46 47
if(extension_loaded('gd') AND function_exists('imageCreateFromJpeg')) {
47 48
	$resize = $_POST['resize'];
48
	$use_captcha = $_POST['use_captcha'];
49 49
} else {
50 50
	$resize = '';
51
	$use_captcha = false;
52 51
}
53 52

  
54 53
// Update settings
trunk/wb/modules/news/comment_page.php
31 31

  
32 32
require_once(WB_PATH.'/include/captcha/captcha.php');
33 33
require_once(WB_PATH.'/include/captcha/asp.php');
34
if(isset($_SESSION['captcha_retry_news'])) unset($_SESSION['captcha_retry_news']);
34 35

  
35 36
// Get comments page template details from db
36 37
$query_settings = $database->query("SELECT comments_page,use_captcha,commenting FROM ".TABLE_PREFIX."mod_news_settings WHERE section_id = '".SECTION_ID."'");
......
57 58
	URL:
58 59
	<label for="url">Don't write anything in this url field:</label>
59 60
	<input id="url" name="url" size="60" value="" /><br />
61
	Comment:
62
	<label for="comment">Leave not your comment here:</label>
63
	<input id="comment" name="comment" size="60" value="" /><br />
60 64
	</p>
61 65
	<?php }
62 66
	?>
......
64 68
	<br />
65 69
	<input type="text" name="title" maxlength="255" style="width: 90%;"<?php if(isset($_SESSION['comment_title'])) { echo ' value="'.$_SESSION['comment_title'].'"'; unset($_SESSION['comment_title']); } ?> />
66 70
	<br /><br />
67
	<?php echo $TEXT['COMMENT']; ?>:
71
	<?php echo $TEXT['COMMENT']; 
72
	// naming this field c0mment is part of ASP
73
	?>:
68 74
	<br />
69
	<textarea name="comment" style="width: 90%; height: 150px;"><?php if(isset($_SESSION['comment_body'])) { echo $_SESSION['comment_body']; unset($_SESSION['comment_body']); } ?></textarea>
75
	<textarea name="c0mment" style="width: 90%; height: 150px;"><?php if(isset($_SESSION['comment_body'])) { echo $_SESSION['comment_body']; unset($_SESSION['comment_body']); } ?></textarea>
70 76
	<br /><br />
71 77
	<?php
72 78
	if(isset($_SESSION['captcha_error'])) {
73 79
		echo '<font color="#FF0000">'.$_SESSION['captcha_error'].'</font><br />';
74 80
		unset($_SESSION['captcha_error']);
81
		$_SESSION['captcha_retry_news'] = true;
75 82
	}
76 83
	// Captcha
77 84
	if($settings['use_captcha']) {
trunk/wb/modules/news/comment.php
27 27
require('../../config.php');
28 28

  
29 29
// Check if there is a post id
30
if(!isset($_GET['id']) OR !is_numeric($_GET['id'])) {
30
if(!isset($_GET['id']) OR !is_numeric($_GET['id']) OR !isset($_GET['sid']) OR !is_numeric($_GET['sid'])) {
31 31
	header("Location: ".WB_URL.PAGES_DIRECTORY."");
32 32
	exit(0);
33 33
}
......
64 64
		exit(0);
65 65
	}
66 66

  
67
	// don't allow commenting if ASP enabled and user doesn't comes from view.php
68
	if(ENABLED_ASP && !isset($_SESSION['comes_from_view'])) {
67
	// don't allow commenting if ASP enabled and user doesn't comes from the right view.php
68
	if(ENABLED_ASP && (!isset($_SESSION['comes_from_view']) OR $_SESSION['comes_from_view']!=POST_ID)) {
69 69
		header("Location: ".WB_URL.PAGES_DIRECTORY."");
70 70
		exit(0);
71 71
	}
......
83 83
		require(WB_PATH.'/index.php');
84 84
	}
85 85
}
86
var_dump($_SESSION);
86 87

  
87

  
88 88
?>
trunk/wb/modules/news/submit_comment.php
30 30
$wb = new wb;
31 31

  
32 32
// Check if we should show the form or add a comment
33
if(is_numeric($_GET['page_id']) AND is_numeric($_GET['section_id']) AND isset($_GET['post_id']) AND is_numeric($_GET['post_id']) AND isset($_POST['comment']) AND $_POST['comment'] != '') {
33
if(is_numeric($_GET['page_id']) AND is_numeric($_GET['section_id']) AND isset($_GET['post_id']) AND is_numeric($_GET['post_id']) AND isset($_POST['c0mment']) AND $_POST['c0mment'] != '') {
34 34
	
35 35
	// Check captcha
36 36
	$query_settings = $database->query("SELECT use_captcha FROM ".TABLE_PREFIX."mod_news_settings WHERE section_id = '".$_GET['section_id']."'");
......
45 45
			(!isset($_SESSION['comes_from_view_time']) OR $_SESSION['comes_from_view_time'] > $t-ASP_VIEW_MIN_AGE) OR // user is too fast
46 46
			(!isset($_SESSION['submitted_when']) OR !isset($_POST['submitted_when'])) OR // faked form
47 47
			($_SESSION['submitted_when'] != $_POST['submitted_when']) OR // faked form
48
			($_SESSION['submitted_when'] > $t-ASP_INPUT_MIN_AGE) OR // user too fast
48
			($_SESSION['submitted_when'] > $t-ASP_INPUT_MIN_AGE && !isset($_SESSION['captcha_retry_news'])) OR // user too fast
49 49
			($_SESSION['submitted_when'] < $t-43200) OR // form older than 12h
50
			($_POST['email'] OR $_POST['url'] OR $_POST['homepage']) // honeypot-fields
50
			($_POST['email'] OR $_POST['url'] OR $_POST['homepage'] OR $_POST['comment']) // honeypot-fields
51 51
		)) {
52 52
			exit(header("Location: ".WB_URL.PAGES_DIRECTORY.""));
53 53
		}
......
57 57
				if(!isset($_POST['captcha']) OR !isset($_SESSION['captcha']) OR $_POST['captcha'] != $_SESSION['captcha']) {
58 58
					$_SESSION['captcha_error'] = $MESSAGE['MOD_FORM']['INCORRECT_CAPTCHA'];
59 59
					$_SESSION['comment_title'] = $_POST['title'];
60
					$_SESSION['comment_body'] = $_POST['comment'];
60
					$_SESSION['comment_body'] = $_POST['c0mment'];
61 61
					exit(header('Location: '.WB_URL."/modules/news/comment.php?id={$_GET['post_id']}&sid={$_GET['section_id']}"));
62 62
				}
63 63
			} else {
64 64
				$_SESSION['captcha_error'] = $MESSAGE['MOD_FORM']['INCORRECT_CAPTCHA'];
65 65
				$_SESSION['comment_title'] = $_POST['title'];
66
				$_SESSION['comment_body'] = $_POST['comment'];
66
				$_SESSION['comment_body'] = $_POST['c0mment'];
67 67
				exit(header('Location: '.WB_URL."/modules/news/comment.php?id={$_GET['post_id']}&sid={$_GET['section_id']}"));
68 68
			}
69 69
		}
......
80 80
	$section_id = $_GET['section_id'];
81 81
	$post_id = $_GET['post_id'];
82 82
	$title = $wb->add_slashes(strip_tags($_POST['title']));
83
	$comment = $wb->add_slashes(strip_tags($_POST['comment']));
83
	$comment = $wb->add_slashes(strip_tags($_POST['c0mment']));
84 84
	$commented_when = mktime();
85 85
	if($wb->is_authenticated() == true) {
86 86
		$commented_by = $wb->get_user_id();

Also available in: Unified diff