/
signup_page.php
122 lines (111 loc) · 4.42 KB
/
signup_page.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
<?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/>.
/**
* @package MantisBT
* @copyright Copyright (C) 2000 - 2002 Kenzaburo Ito - kenito@300baud.org
* @copyright Copyright (C) 2002 - 2012 MantisBT Team - mantisbt-dev@lists.sourceforge.net
* @link http://www.mantisbt.org
*
* @uses core.php
* @uses config_api.php
* @uses constant_inc.php
* @uses crypto_api.php
* @uses form_api.php
* @uses helper_api.php
* @uses html_api.php
* @uses lang_api.php
* @uses print_api.php
* @uses utility_api.php
*/
/**
* MantisBT Core API's
*/
require_once( 'core.php' );
require_api( 'config_api.php' );
require_api( 'constant_inc.php' );
require_api( 'crypto_api.php' );
require_api( 'form_api.php' );
require_api( 'helper_api.php' );
require_api( 'html_api.php' );
require_api( 'lang_api.php' );
require_api( 'print_api.php' );
require_api( 'utility_api.php' );
require_css( 'login.css' );
# Check for invalid access to signup page
if ( OFF == config_get_global( 'allow_signup' ) || LDAP == config_get_global( 'login_method' ) ) {
print_header_redirect( 'login_page.php' );
}
# signup page shouldn't be indexed by search engines
html_robots_noindex();
html_page_top1();
html_page_top2a();
$t_public_key = crypto_generate_uri_safe_nonce( 64 );
?>
<div id="signup-div" class="form-container">
<form id="signup-form" method="post" action="signup.php">
<fieldset>
<legend><span><?php echo lang_get( 'signup_title' ) ?></span></legend>
<?php echo form_security_field( 'signup' ); ?>
<ul id="login-links">
<li><a href="login_page.php"><?php echo lang_get( 'login_link' ); ?></a></li>
<?php
# lost password feature disabled or reset password via email disabled
if ( ( LDAP != config_get_global( 'login_method' ) ) &&
( ON == config_get( 'lost_password_feature' ) ) &&
( ON == config_get( 'send_reset_password' ) ) &&
( ON == config_get( 'enable_email_notification' ) ) ) {
echo '<li><a href="lost_pwd_page.php">', lang_get( 'lost_password_link' ), '</a></li>';
}
?>
</ul>
<div class="field-container">
<label for="username"><span><?php echo lang_get( 'username' ) ?></span></label>
<span class="input"><input id="username" type="text" name="username" size="32" maxlength="<?php echo USERLEN;?>" class="autofocus" /></span>
<span class="label-style"></span>
</div>
<div class="field-container">
<label for="email-field"><span><?php echo lang_get( 'email_label' ) ?></span></label>
<span class="input"><?php print_email_input( 'email', '' ) ?></span>
<span class="label-style"></span>
</div>
<?php
$t_allow_passwd = helper_call_custom_function( 'auth_can_change_password', array() );
if( ON == config_get( 'signup_use_captcha' ) && ( true == $t_allow_passwd ) ) {
# captcha image requires GD library and related option to ON
if( !extension_loaded('gd') ) {
throw new MantisBT\Exception\Missing_GD_Extension();
}
echo '<div class="field-container">';
echo '<label for="captcha-field"><span>' . lang_get( 'signup_captcha_request_label' ) . '</span></label>';
echo '<span id="captcha-input" class="input">';
print_captcha_input( 'captcha', '' );
echo '<span class="captcha-image"><img src="make_captcha_img.php?public_key=' . $t_public_key . '" alt="visual captcha" /></span>';
echo '</span>';
echo '<input type="hidden" name="public_key" value="' . $t_public_key . '" />';
echo '<span class="label-style"></span>';
echo '</div>';
}
if( false == $t_allow_passwd ) {
echo '<span id="no-password-msg">';
echo lang_get( 'no_password_request' );
echo '</span>';
}
?>
<span id="signup-info"><?php echo lang_get( 'signup_info' ); ?></span>
<span class="submit-button"><input type="submit" class="button" value="<?php echo lang_get( 'signup_button' ) ?>" /></span>
</fieldset>
</form>
</div>
<?php html_page_bottom1a( __FILE__ );