notify('NOTIFY_HEADER_START_ACCOUNT_PASSWORD'); if (!$_SESSION['customer_id']) { $_SESSION['navigation']->set_snapshot(); zen_redirect(zen_href_link(FILENAME_LOGIN, '', 'SSL')); } require(DIR_WS_MODULES . zen_get_module_directory('require_languages.php')); if (isset($_POST['action']) && ($_POST['action'] == 'process')) { $password_current = zen_db_prepare_input($_POST['password_current']); $password_new = zen_db_prepare_input($_POST['password_new']); $password_confirmation = zen_db_prepare_input($_POST['password_confirmation']); $error = false; if (strlen($password_new) < ENTRY_PASSWORD_MIN_LENGTH) { $error = true; $messageStack->add('account_password', ENTRY_PASSWORD_NEW_ERROR); } elseif ($password_new != $password_confirmation) { $error = true; $messageStack->add('account_password', ENTRY_PASSWORD_NEW_ERROR_NOT_MATCHING); } if ($error == false) { $check_customer_query = "SELECT customers_password, customers_nick FROM " . TABLE_CUSTOMERS . " WHERE customers_id = :customersID"; $check_customer_query = $db->bindVars($check_customer_query, ':customersID',$_SESSION['customer_id'], 'integer'); $check_customer = $db->Execute($check_customer_query); if (zen_validate_password($password_current, $check_customer->fields['customers_password'])) { $nickname = $check_customer->fields['customers_nick']; $sql = "UPDATE " . TABLE_CUSTOMERS . " SET customers_password = :password WHERE customers_id = :customersID"; $sql = $db->bindVars($sql, ':customersID',$_SESSION['customer_id'], 'integer'); $sql = $db->bindVars($sql, ':password',zen_encrypt_password($password_new), 'string'); $db->Execute($sql); $sql = "UPDATE " . TABLE_CUSTOMERS_INFO . " SET customers_info_date_account_last_modified = now() WHERE customers_info_id = :customersID"; $sql = $db->bindVars($sql, ':customersID',$_SESSION['customer_id'], 'integer'); $db->Execute($sql); if ($phpBB->phpBB['installed'] == true) { if (zen_not_null($nickname) && $nickname != '') { $phpBB->phpbb_change_password($nickname, $password_new); } } $messageStack->add_session('account', SUCCESS_PASSWORD_UPDATED, 'success'); zen_redirect(zen_href_link(FILENAME_ACCOUNT, '', 'SSL')); } else { $error = true; $messageStack->add('account_password', ERROR_CURRENT_PASSWORD_NOT_MATCHING); } } } $breadcrumb->add(NAVBAR_TITLE_1, zen_href_link(FILENAME_ACCOUNT, '', 'SSL')); $breadcrumb->add(NAVBAR_TITLE_2); // This should be last line of the script: $zco_notifier->notify('NOTIFY_HEADER_END_ACCOUNT_PASSWORD');