/
check_email_inc.php
124 lines (108 loc) · 4.05 KB
/
check_email_inc.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
# MantisBT - A PHP based bugtracking system
# MantisBT is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
#
# MantisBT is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with MantisBT. If not, see <http://www.gnu.org/licenses/>.
/**
* This file contains configuration checks for email issues
*
* @package MantisBT
* @copyright Copyright 2000 - 2002 Kenzaburo Ito - kenito@300baud.org
* @copyright Copyright 2002 MantisBT Team - mantisbt-dev@lists.sourceforge.net
* @link http://www.mantisbt.org
*
* @uses check_api.php
* @uses config_api.php
* @uses utility_api.php
*/
if( !defined( 'CHECK_EMAIL_INC_ALLOW' ) ) {
return;
}
# MantisBT Check API
require_once( 'check_api.php' );
require_api( 'config_api.php' );
require_api( 'utility_api.php' );
require_api( 'database_api.php' );
check_print_section_header_row( 'Email' );
$t_email_options = array(
'webmaster_email',
'from_email',
'return_path_email'
);
foreach( $t_email_options as $t_email_option ) {
$t_email = config_get_global( $t_email_option );
check_print_test_row(
$t_email_option . ' configuration option has a valid email address specified',
!preg_match( '/@example\.com$/', $t_email ),
array( false => 'You need to specify a valid email address for the ' . $t_email_option . ' configuration option.' )
);
}
check_print_test_warn_row(
'Email addresses are validated',
config_get_global( 'validate_email' ),
array( false => 'You have disabled email validation checks. For security reasons it is suggested that you enable these validation checks.' )
);
check_print_test_row(
'send_reset_password = ON requires allow_blank_email = OFF',
!config_get_global( 'send_reset_password' ) || !config_get_global( 'allow_blank_email' )
);
check_print_test_row(
'send_reset_password = ON requires enable_email_notification = ON',
!config_get_global( 'send_reset_password' ) || config_get_global( 'enable_email_notification' )
);
check_print_test_row(
'allow_signup = ON requires enable_email_notification = ON',
!config_get_global( 'allow_signup' ) || config_get_global( 'enable_email_notification' )
);
check_print_test_row(
'allow_signup = ON requires send_reset_password = ON',
!config_get_global( 'allow_signup' ) || config_get_global( 'send_reset_password' )
);
# Check for duplicate email addresses (case-insensitive)
$t_duplicate_emails = user_get_duplicate_emails();
# Format usernames for display with link to user edit page
$t_user_edit_page = helper_mantis_url( 'manage_user_edit_page.php' ) . '?user_id=';
foreach( $t_duplicate_emails as &$t_users ) {
foreach( $t_users as $t_id => &$t_username ) {
$t_username = sprintf( '<a href="%s">%s</a>',
$t_user_edit_page . $t_id,
string_display_line( $t_username )
);
}
}
if( OFF == config_get_global( 'allow_blank_email' ) ) {
$t_users_without_email = $t_duplicate_emails[null] ?? [];
check_print_test_row(
'All users must have an e-mail address',
empty( $t_users_without_email ),
count( $t_users_without_email ) . " users without e-mail address found: "
. implode( ', ', $t_users_without_email ),
);
}
# Fail check if emails should be unique, just issue a warning otherwise
$t_function = config_get_global( 'email_ensure_unique' )
? 'check_print_test_row'
: 'check_print_test_warn_row';
$t_list = '<ul>';
foreach( $t_duplicate_emails as $t_email => $t_usernames ) {
$t_list .= '<li>'
. ( $t_email ?: '(no e-mail)' )
. ' (' . count( $t_usernames ) . '): '
. implode( ', ', $t_usernames )
. '</li>';
}
$t_list .= '</ul>';
$t_function(
'There are no duplicate email addresses, regardless of case',
count( $t_duplicate_emails ) == 0,
count( $t_duplicate_emails ) . ' duplicate e-mail addresses found: ' . $t_list
);