| 
<?php
 /*
 From WordPress
 */
 if (!function_exists('bt_autop')) {
 function bt_autop($pee, $br = 1) {
 $pee = $pee . "\n"; // just to make things a little easier, pad the end
 $pee = preg_replace('|<br />\s*<br />|', "\n\n", $pee);
 // Space things out a little
 $allblocks = '(?:table|thead|tfoot|caption|colgroup|tbody|tr|td|th|div|dl|dd|dt|ul|ol|li|pre|select|form|map|area|blockquote|address|math|style|input|p|h[1-6]|hr)';
 $pee = preg_replace('!(<' . $allblocks . '[^>]*>)!', "\n$1", $pee);
 $pee = preg_replace('!(</' . $allblocks . '>)!', "$1\n\n", $pee);
 $pee = str_replace(array("\r\n", "\r"), "\n", $pee); // cross-platform newlines
 $pee = preg_replace("/\n\n+/", "\n\n", $pee); // take care of duplicates
 $pee = preg_replace('/\n?(.+?)(?:\n\s*\n|\z)/s', "<p>$1</p>\n", $pee); // make paragraphs, including one at the end
 $pee = preg_replace('|<p>\s*?</p>|', '', $pee); // under certain strange conditions it could create a P of entirely whitespace
 $pee = preg_replace('!<p>([^<]+)\s*?(</(?:div|address|form)[^>]*>)!', "<p>$1</p>$2", $pee);
 $pee = preg_replace( '|<p>|', "$1<p>", $pee );
 $pee = preg_replace('!<p>\s*(</?' . $allblocks . '[^>]*>)\s*</p>!', "$1", $pee); // don't pee all over a tag
 $pee = preg_replace("|<p>(<li.+?)</p>|", "$1", $pee); // problem with nested lists
 $pee = preg_replace('|<p><blockquote([^>]*)>|i', "<blockquote$1><p>", $pee);
 $pee = str_replace('</blockquote></p>', '</p></blockquote>', $pee);
 $pee = preg_replace('!<p>\s*(</?' . $allblocks . '[^>]*>)!', "$1", $pee);
 $pee = preg_replace('!(</?' . $allblocks . '[^>]*>)\s*</p>!', "$1", $pee);
 if ($br) {
 $pee = preg_replace('/<(script|style).*?<\/\\1>/se', 'str_replace("\n", "<WPPreserveNewline />", "\\0")', $pee);
 $pee = preg_replace('|(?<!<br />)\s*\n|', "<br />\n", $pee); // optionally make line breaks
 $pee = str_replace('<WPPreserveNewline />', "\n", $pee);
 }
 $pee = preg_replace('!(</?' . $allblocks . '[^>]*>)\s*<br />!', "$1", $pee);
 $pee = preg_replace('!<br />(\s*</?(?:p|li|div|dl|dd|dt|th|pre|td|ul|ol)[^>]*>)!', '$1', $pee);
 /*
 if (strpos($pee, '<pre') !== false)
 $pee = preg_replace('!(<pre.*?>)(.*?)</pre>!ise', " stripslashes('$1') .  stripslashes(clean_pre('$2'))  . '</pre>' ", $pee);
 */
 $pee = preg_replace( "|\n</p>$|", '</p>', $pee );
 
 return $pee;
 }
 }
 
 if (!function_exists('bt_login')) {
 function bt_login($user_name, $password, $already_md5 = FALSE) {
 global $bt_db, $bt_tb, $bt_session;
 
 if (empty($password)) return false;
 
 $user_name = strtolower($user_name);
 
 if (!$already_md5) $password = md5($password);
 
 $query = "SELECT * FROM $bt_tb->users WHERE active = 1 AND user_name = :username LIMIT 1";
 
 $stmt = $bt_db->prepare($query);
 $stmt->bindParam(':username', $user_name);
 
 try {
 $stmt->execute();
 }
 catch (Exception $e) {
 bt_die($e->getMessage());
 }
 
 $user = $stmt->fetchAll(PDO::FETCH_ASSOC);
 
 if (!empty($user)) {
 if ($user[0]['password'] === $password) {
 $bt_session->regenerate_id();
 trigger_error('Login Successful "' . bt_htmlentities($user_name) . '"', E_USER_NOTICE);
 
 //setup session here
 $user_array = array(
 'user_id' => $user[0]['user_id'],
 );
 
 $_SESSION['bt_user_data'] = $user_array;
 
 return true;
 }
 else {
 trigger_error('Login Failed (Incorrect Password) "' . bt_htmlentities($user_name) . '"', E_USER_WARNING);
 return false;
 }
 }
 else {
 trigger_error('Login Failed (Unknown User) "' . bt_htmlentities($user_name) . '"', E_USER_WARNING);
 return false;
 }
 
 }
 }
 
 if (!function_exists('bt_logout')) {
 function bt_logout() {
 
 trigger_error('Logout Successful "' . bt_htmlentities(bt_get_user_data('user_name')) . '"', E_USER_NOTICE);
 
 session_destroy();
 
 return true;
 }
 }
 
 ?>
 |