-
Notifications
You must be signed in to change notification settings - Fork 2
/
change_password.php
77 lines (66 loc) · 2.64 KB
/
change_password.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
<?php
/**
* change password
*
* @copyright (c) 2004-15 bitweaver.org
*
* @package users
* @subpackage functions
*/
/**
* required setup
*/
require_once( '../kernel/includes/setup_inc.php' );
if( !isset( $_REQUEST['login'] )) {
$_REQUEST['login'] = '';
}
if( !isset( $_REQUEST['user_id'] )) {
$_REQUEST['user_id'] = '';
}
if( !isset( $_REQUEST["oldpass"] )) {
$_REQUEST["oldpass"] = '';
}
if( !isset( $_REQUEST["provpass"] )) {
$_REQUEST["provpass"] = '';
}
$gBitSmarty->assign( 'login', $_REQUEST['login'] );
$gBitSmarty->assign( 'oldpass', $_REQUEST["oldpass"] );
$gBitSmarty->assign( 'provpass', $_REQUEST["provpass"] );
$userInfo = $gBitUser->getUserInfo( array( 'user_id' => $_REQUEST['user_id'] ));
$gBitSmarty->assignByRef( 'userInfo', $userInfo );
if( isset( $_REQUEST["change"] )) {
if( $_REQUEST["pass"] == $_REQUEST["oldpass"] ) {
$gBitSystem->fatalError( tra( "You can not use the same password again" ));
}
if( $passswordError = $gBitUser->verifyPasswordFormat( $_REQUEST["pass"], $_REQUEST["pass2"] )) {
$gBitSystem->fatalError( tra( $passswordError ));
}
$validated = FALSE;
if( !empty( $_REQUEST["provpass"] ) ) {
if( $validated = $gBitUser->confirmRegistration( $userInfo['user_id'], $_REQUEST["provpass"] ) ) {
if( $gBitSystem->isFeatureActive( 'send_welcome_email' ) ) {
$siteName = $gBitSystem->getConfig( 'site_title', $_SERVER['HTTP_HOST'] );
// Send the welcome mail
$gBitSmarty->assign( 'siteName', $_SERVER["SERVER_NAME"] );
$gBitSmarty->assign( 'mail_site', $_SERVER["SERVER_NAME"] );
$gBitSmarty->assign( 'mail_user', $userInfo['login'] );
$gBitSmarty->assign( 'mailPassword',$_REQUEST['pass'] );
$gBitSmarty->assign( 'mailEmail',$validated['email'] );
$mail_data = $gBitSmarty->fetch('bitpackage:users/welcome_mail.tpl');
mail($validated["email"], tra( 'Welcome to' ).' '.$siteName,$mail_data,"From: ".$gBitSystem->getConfig('site_sender_email')."\r\nContent-type: text/plain;charset=utf-8\r\n");
}
} else {
$gBitSystem->fatalError( tra("Password reset request is invalid or has expired") );
}
} elseif( !( $validated = $gBitUser->validate( $userInfo['email'], $_REQUEST["oldpass"], '', '' )) ) {
$gBitSystem->fatalError( tra("Invalid old password") );
}
if( $validated ) {
$gBitUser->storePassword( $_REQUEST["pass"], (!empty( $userInfo['login'] )?$userInfo['login']:$userInfo['email']) );
$url = $gBitUser->login( (!empty( $userInfo['login'] )?$userInfo['login']:$userInfo['email']), $_REQUEST["pass"] );
}
bit_redirect( $url );
}
// Display the template
$gBitSystem->display( 'bitpackage:users/change_password.tpl', 'Change Password' , array( 'display_mode' => 'display' ));
?>