true, 'mysql_clean' => false)) { if ($array['no_html']) $string = htmlentities($string); if ($array['special_html']) $string = htmlspecialchars($string); if ($array['mysql_clean']) $string = mysql_real_escape_string($string); if ($array['nl2br']) $string = nl2br($string); return $string; } //This Fucntion is for Securing Password, // you may change its combination for security reason but make // sure dont not rechange once you made your script run function pass_code($string) { $password = md5(md5(sha1(sha1(md5($string))))); return $password; } //Mysql Clean Queries function sql_free($id) { if (!get_magic_quotes_gpc()) { $id = addslashes($id); } return $id; } function mysql_clean($id, $replacer = true) { //$id = clean($id); if (get_magic_quotes_gpc()) { $id = stripslashes($id); } $id = htmlspecialchars(mysql_real_escape_string($id)); if ($replacer) $id = Replacer($id); return $id; } function escape_gpc($in) { if (get_magic_quotes_gpc()) { $in = stripslashes($in); } return $in; } function filter_sql($data) { $data = mysql_real_escape_string($data); return $data; } //Redirect Using JAVASCRIPT function redirect_to($url) { echo ''; exit("Javascript is turned off, click here to go to requested page"); } //Funtion of Random String function RandomString($length) { $string = md5(microtime()); $highest_startpoint = 32 - $length; $randomString = substr($string, rand(0, $highest_startpoint), $length); return $randomString; } //This Function Is Used To Display Tags Cloud function TagClouds($cloudquery) { $tags = array(); $cloud = array(); $query = mysql_query($cloudquery); while ($t = mysql_fetch_array($query)) { $db = explode(' ', $t[0]); while (list($key, $value) = each($db)) { @$keyword[$value] += 1; } } if (is_array(@$keyword)) { $minFont = 11; $maxFont = 22; $min = min(array_values($keyword)); $max = max(array_values($keyword)); $fix = ($max - $min == 0) ? 1 : $max - $min; // Display the tags foreach ($keyword as $tag => $count) { $size = $minFont + ($count - $min) * ($maxFont - $minFont) / $fix; $cloud[] = '' . mysql_clean($tag) . ''; } $shown = join("\n", $cloud) . "\n"; return $shown; } } /** * Function used to send emails * @Author : Arslan Hassan * this is a very basic email function * you can extend or replace this function easily * read our docs.clip-bucket.com */ function cbmail($array) { $func_array = get_functions('email_functions'); if (is_array($func_array)) { foreach ($func_array as $func) { if (function_exists($func)) { return $func($array); } } } $content = escape_gpc($array['content']); $subject = escape_gpc($array['subject']); $to = $array['to']; $from = $array['from']; $to_name = $array['to_name']; $from_name = $array['from_name']; if ($array['nl2br']) $content = nl2br($content); # CHecking Content if (preg_match('//', $content, $matches)) { if (empty($matches[1])) { $content = wrap_email_content($content); } } $message .= $content; //ClipBucket uses PHPMailer for sending emails include_once("classes/phpmailer/class.phpmailer.php"); include_once("classes/phpmailer/class.smtp.php"); $mail = new PHPMailer(); // defaults to using php "mail()" $mail_type = config('mail_type'); //---Setting SMTP --- if ($mail_type == 'smtp') { $mail->IsSMTP(); // telling the class to use SMTP $mail->Host = config('smtp_host'); // SMTP server if (config('smtp_auth') == 'yes') $mail->SMTPAuth = true; // enable SMTP authentication $mail->Port = config('smtp_port'); // set the SMTP port for the GMAIL server $mail->Username = config('smtp_user'); // SMTP account username $mail->Password = config('smtp_pass'); // SMTP account password } //--- Ending Smtp Settings $mail->SetFrom($from, $from_name); if (is_array($to)) { foreach ($to as $name) { $mail->AddAddress(strtolower($name), $to_name); } } else { $mail->AddAddress(strtolower($to), $to_name); } $mail->Subject = $subject; $mail->MsgHTML($message); if (!$mail->Send()) { if (!DEVELOPMENT_MODE) e("Mailer Error: " . $mail->ErrorInfo); return false; }else return true; } function send_email($from, $to, $subj, $message) { return cbmail(array('from' => $from, 'to' => $to, 'subject' => $subj, 'content' => $message)); } /** * Function used to wrap email content in * HTML AND BODY TAGS */ function wrap_email_content($content) { return '
' . $content . ''; } /** * Function used to get file name */ function GetName($file) { if (!is_string($file)) return false; $path = explode('/', $file); if (is_array($path)) $file = $path[count($path) - 1]; $new_name = substr($file, 0, strrpos($file, '.')); return $new_name; } function get_elapsed_time($ts, $datetime = 1) { if ($datetime == 1) { $ts = date('U', strtotime($ts)); } $mins = floor((time() - $ts) / 60); $hours = floor($mins / 60); $mins -= $hours * 60; $days = floor($hours / 24); $hours -= $days * 24; $weeks = floor($days / 7); $days -= $weeks * 7; $t = ""; if ($weeks > 0) return "$weeks week" . ($weeks > 1 ? "s" : ""); if ($days > 0) return "$days day" . ($days > 1 ? "s" : ""); if ($hours > 0) return "$hours hour" . ($hours > 1 ? "s" : ""); if ($mins > 0) return "$mins min" . ($mins > 1 ? "s" : ""); return "< 1 min"; } //Function Used TO Get Extensio Of File function GetExt($file) { return strtolower(substr($file, strrpos($file, '.') + 1)); } //Simple Validation function isValidText($text) { $pattern = "^^[_a-z0-9-]+$"; if (eregi($pattern, $text)) { return true; } else { return false; } } //Function Used To Validate Email function isValidEmail($email) { $pattern = "/[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,3})$/i"; preg_match($pattern, $email, $matches); if ($matches[0] != '') { return true; } else { if (!DEVELOPMENT_MODE) return false; else return true; } } // THIS FUNCTION SETS HTMLSPECIALCHARS_DECODE IF FUNCTION DOESN'T EXIST // INPUT: $text REPRESENTING THE TEXT TO DECODE // $ent_quotes (OPTIONAL) REPRESENTING WHETHER TO REPLACE DOUBLE QUOTES, ETC // OUTPUT: A STRING WITH HTML CHARACTERS DECODED if (!function_exists('htmlspecialchars_decode')) { function htmlspecialchars_decode($text, $ent_quotes = "") { $text = str_replace(""", "\"", $text); $text = str_replace("'", "'", $text); $text = str_replace("<", "<", $text); $text = str_replace(">", ">", $text); $text = str_replace("&", "&", $text); return $text; } } // END htmlspecialchars() FUNCTION //THIS FUNCTION IS USED TO LIST FILE TYPES IN FLASH UPLOAD //INPUT FILE TYPES //OUTPUT FILE TYPE IN PROPER FORMAT function ListFileTypes($types) { $types_array = preg_replace('/,/', ' ', $types); $types_array = explode(' ', $types_array); $list = 'Video,'; for ($i = 0; $i <= count($types_array); $i++) { if ($types_array[$i] != '') { $list .= '*.' . $types_array[$i]; if ($i != count($types_array)) $list .= ';'; } } return $list; } /** * Get Directory Size - get_video_file($vdata,$no_video,false); */ function get_directory_size($path) { $totalsize = 0; $totalcount = 0; $dircount = 0; if ($handle = opendir($path)) { while (false !== ($file = readdir($handle))) { $nextpath = $path . '/' . $file; if ($file != '.' && $file != '..' && !is_link($nextpath)) { if (is_dir($nextpath)) { $dircount++; $result = get_directory_size($nextpath); $totalsize += $result['size']; $totalcount += $result['count']; $dircount += $result['dircount']; } elseif (is_file($nextpath)) { $totalsize += filesize($nextpath); $totalcount++; } } } } closedir($handle); $total['size'] = $totalsize; $total['count'] = $totalcount; $total['dircount'] = $dircount; return $total; } //FUNCTION USED TO FORMAT FILE SIZE //INPUT BYTES //OUTPT MB , Kib function formatfilesize($data) { // bytes if ($data < 1024) { return $data . " bytes"; } // kilobytes else if ($data < 1024000) { return round(( $data / 1024), 1) . "KB"; } // megabytes else if ($data < 1024000000) { return round(( $data / 1024000), 1) . " MB"; } else { return round(( $data / 1024000000), 1) . " GB"; } } //TEST EXCEC FUNCTION function test_exec($cmd) { echo 'FAILED: $cmd
' . htmlentities($data) . ''; } /** * Function used to get shell output */ function shell_output($cmd) { if (stristr(PHP_OS, 'WIN')) { $cmd = $cmd; } else { $cmd = "PATH=\$PATH:/bin:/usr/bin:/usr/local/bin bash -c \"$cmd\" 2>&1"; } $data = shell_exec($cmd); return $data; } /** * Function used to tell ClipBucket that it has closed the script */ function the_end() { if (!$isWorthyBuddy) { echo 'Nothing to do here anymore'; } } /** * FUNCTION USED TO GET COMMENTS * @param : array(); */ function getComments($params = NULL) { global $db; $order = $params['order']; $limit = $params['limit']; $type = $params['type']; $cond = ''; if (empty($type)) $type = "v"; $cond .= tbl("comments.type") . " = '" . $type . "'"; if ($params['type_id'] && $params['sectionTable']) { if ($cond != "") $cond .= " AND "; $cond .= tbl("comments.type_id") . " = " . tbl($params['sectionTable'] . "." . $params['type_id']); } if ($params['cond']) { if ($cond != "") $cond .= " AND "; $cond .= $params['cond']; } if (!$params['count_only']) $result = $db->select(tbl("comments" . ($params['sectionTable'] ? "," . $params['sectionTable'] : NULL)), "*", $cond, $limit, $order); //echo $db->db_query; if ($params['count_only']) $result = $db->count(tbl("comments"), "*", $cond); if ($result) return $result; else return false; } function out($link) { return BASEURL . '/out.php?l=' . urlencode($link); } /** * this_page() * * get current page name as defined in THIS_PAGE static variable * * @param STRING $page_name * @return STRING current_page */ function this_page($page) { if (defined('THIS_PAGE')) return THIS_PAGE; else return 'index'; } /** * isValidToken() * * validate input token given in $_POST request when submitting data in * ClipBucket. * * @param STRING $token * @param STRING $method * * return BOOLEAN */ function isValidToken($token, $method = NULL) { $fullToken = getToken($method); if ($fullToken != $token) return false; else { return true; } } /** * getToken() * * Function used to get current token * * @param STRING $method * @return STRING $token */ function getToken($method = NULL) { $sess = session_id(); $ip = $_SERVER['REMOTE_ADDR']; $webkey = ""; if (defined('CB_WEBSITE_KEY')) { $webkey = CB_WEBSITE_KEY; } if ($webkey) $fullToken = md5($sess . $method . $ip . $webkey); else $fullToken = md5($sess . $method . $ip); return $fullToken; } /** * createDataFolders() * * create date folders with respect to date. so that no folder gets overloaded * with number of files. * * @param string FOLDER, if set to null, sub-date-folders will be created in * all data folders * @return string */ function createDataFolders($headFolder = NULL, $custom_date = NULL) { $time = time(); if ($custom_date) $time = strtotime($custom_date); $year = date("Y", $time); $month = date("m", $time); $day = date("d", $time); $folder = $year . '/' . $month . '/' . $day; $data = cb_call_functions('dated_folder'); if ($data) return $data; if (!$headFolder) { @mkdir(VIDEOS_DIR . '/' . $folder, 0777, true); @mkdir(THUMBS_DIR . '/' . $folder, 0777, true); @mkdir(ORIGINAL_DIR . '/' . $folder, 0777, true); @mkdir(PHOTOS_DIR . '/' . $folder, 0777, true); @mkdir(LOGS_DIR . '/' . $folder, 0777, true); } else { if (!file_exists($headFolder . '/' . $folder)) { @mkdir($headFolder . '/' . $folder, 0777, true); } } $folder = apply_filters($folder, 'dated_folder'); return $folder; } function create_dated_folder($headFolder = NULL, $custom_date = NULL) { return createDataFolders($headFolder, $custom_date); } /** * Gets the list of comments and assign it the given paramter * @global type $myquery * @param type $params ARGUMENTS , assign=variable to assign comments array * in smarty template, read getComments for more information * @return ARRAY $comments */ function getSmartyComments($params) { global $myquery; $comments = $myquery->getComments($params); if ($params['assign']) assign($params['assign'], $comments); else return $comments; } /** * This wil get an Advertisment from database and display it * * @global type $adsObj * @param ARRAY (style,class,align,place) * style = Css Styling on div wrapping AD * class = class of div wrapping AD * place = AD placement code e.g ad_300x250 * @return string */ function getAd($params) { global $adsObj; $data = ''; if ($params['style'] || $params['class'] || $params['align']) $data .= '
"; print_r($text); echo ""; } } /** * This function is used to call function in smarty template * This wont let you pass parameters to the function, but it will only call it */ function FUNC($params) { global $Cbucket; //Function used to call functions by //{func namefunction_name} // in smarty $func = $params['name']; if (function_exists($func)) $func(); } /** * Function used to return mysql time * @author : Fwhite */ function NOW() { return date('Y-m-d H:i:s', time()); } /** * This funcion used to call function dynamically in smarty */ function load_form($param) { $func = $param['name']; if (function_exists($func)) return $func($param); } /** * Function used to get PHP Path */ function php_path() { if (PHP_PATH != '') return PHP_PATH; else return "/usr/bin/php"; } /** * Functon used to get binary paths */ function get_binaries($path) { if (is_array($path)) { $type = $path['type']; $path = $path['path']; } if ($type == '' || $type == 'user') { $path = strtolower($path); switch ($path) { case "php": return php_path(); break; case "mp4box": return config("mp4boxpath"); break; case "flvtool2": return config("flvtool2path"); break; case "ffmpeg": return config("ffmpegpath"); break; } } else { $path = strtolower($path); switch ($path) { case "php": $return_path = shell_output("which php"); if ($return_path) return $return_path; else return "Unable to find PHP path"; break; case "mp4box": $return_path = shell_output("which MP4Box"); if ($return_path) return $return_path; else return "Unable to find mp4box path"; break; case "flvtool2": $return_path = shell_output("which flvtool2"); if ($return_path) return $return_path; else return "Unable to find flvtool2 path"; break; case "ffmpeg": $return_path = shell_output("which ffmpeg"); if ($return_path) return $return_path; else return "Unable to find ffmpeg path"; break; } } } /** * Function in case htmlspecialchars_decode does not exist */ function unhtmlentities($string) { $trans_tbl = get_html_translation_table(HTML_ENTITIES); $trans_tbl = array_flip($trans_tbl); return strtr($string, $trans_tbl); } /** * Function used to execute command in background */ function bgexec($cmd) { if (substr(php_uname(), 0, 7) == "Windows") { //exec($cmd." >> /dev/null &"); exec($cmd); //pclose(popen("start \"bla\" \"" . $exe . "\" " . escapeshellarg($args), "r")); } else { exec($cmd . " > /dev/null &"); } } /** * Function used to get array value * if you know partial value of array and wants to know complete * value of an array, this function is being used then */ function array_find($needle, $haystack) { foreach ($haystack as $item) { if (strpos($item, $needle) !== FALSE) { return $item; break; } } } /** * Function used to convert input to categories * @param input can be an array or #12# like */ function convert_to_categories($input) { if (is_array($input)) { foreach ($input as $in) { if (is_array($in)) { foreach ($in as $i) { if (is_array($i)) { foreach ($i as $info) { $cat_details = get_category($info); $cat_array[] = array($cat_details['categoryid'], $cat_details['category_name']); } } elseif (is_numeric($i)) { $cat_details = get_category($i); $cat_array[] = array($cat_details['categoryid'], $cat_details['category_name']); } } } elseif (is_numeric($in)) { $cat_details = get_category($in); $cat_array[] = array($cat_details['categoryid'], $cat_details['category_name']); } } } else { preg_match_all('/#([0-9]+)#/', $default['category'], $m); $cat_array = array($m[1]); foreach ($cat_array as $i) { $cat_details = get_category($i); $cat_array[] = array($cat_details['categoryid'], $cat_details['category_name']); } } $count = 1; if (is_array($cat_array)) { foreach ($cat_array as $cat) { echo '' . $cat[1] . ''; if ($count != count($cat_array)) echo ', '; $count++; } } } /** * Function used to get categorie details */ function get_category($id) { global $myquery; return $myquery->get_category($id); } /** * Sharing OPT displaying */ function display_sharing_opt($input) { foreach ($input as $key => $i) { return $key; break; } } /** * Function used to get error_list */ function error_list() { global $eh; return $eh->error_list; } /** * Function used to get msg_list */ function msg_list() { global $eh; return $eh->message_list; } /** * Function used to display hint */ function hint($hint) { } /** * Function used to check weather erro exists or not */ function error($param = 'array') { if (count(error_list()) > 0) { if ($param != 'array') { if ($param == 'single') $param = 0; $msg = error_list(); return $msg[$param]; } return error_list(); }else { return false; } } /** * Function used to check weather msg exists or not */ function msg($param = 'array') { if (count(msg_list()) > 0) { if ($param != 'array') { if ($param == 'single') $param = 0; $msg = msg_list(); return $msg[$param]; } return msg_list(); }else { return false; } } /** * Function used to load plugin * please check docs.clip-bucket.com */ function load_plugin() { global $cbplugin; } /** * Function used to create limit functoin from current page & results */ function create_query_limit($page, $result) { $limit = $result; if (empty($page) || $page == 0 || !is_numeric($page)) { $page = 1; } $from = $page - 1; $from = $from * $limit; return $from . ',' . $result; } /** * Function used to return LANG variable */ function lang($var, $sprintf = false) { global $LANG, $Cbucket; $array_str = array ('{title}'); $array_replace = array ($Cbucket->configs['site_title']); if ($LANG[$var]) { $phrase = str_replace($array_str, $array_replace, $LANG[$var]); } else { $phrase = str_replace($array_str, $array_replace, $var); } if ($sprintf) { $sprints = explode(',', $sprintf); if (is_array($sprints)) { foreach ($sprints as $sprint) { $phrase = sprintf($phrase, $sprint); } } } return $phrase; } /** * Function used to display an ad */ function ad($in) { return stripslashes(htmlspecialchars_decode($in)); } /** * Function used to get * available function list * for special place , read docs.clip-bucket.com */ function get_functions($name) { global $Cbucket; $funcs = $Cbucket->$name; if (is_array($funcs) && count($funcs) > 0) return $funcs; else return false; } /** * Function used to get config value * of ClipBucket */ function config($input, $value = false) { global $Cbucket, $myquery; if (!$value) return $Cbucket->configs[$input]; else { $myquery->Set_Website_Details($input, '|no_mc|' . $value); } } function get_config($input) { return config($input); } /** * Function used to incream number of view * in object */ function increment_views($id, $type = NULL) { global $db; switch ($type) { case 'v': case 'video': default: { $video = get_video_details($id); if (!$video) { return false; } if ($video['active'] != 'yes' || $video['status'] != 'Successful') { return false; } if (function_exists('vi_user_type')) { $_user = vi_user_type(); if ($_user['user_type'] == 4) { return false; } } if (!isset($_COOKIE['video_' . $id])) { $db->update(tbl("video"), array("views", "last_viewed"), array("|f|views+1", NOW()), " videoid='$id' OR videokey='$id'"); setcookie('video_' . $id, 'watched', time() + 3600); } } break; case 'u': case 'user': case 'channel': { if (!isset($_COOKIE['user_' . $id])) { $db->update(tbl("users"), array("profile_hits"), array("|f|profile_hits+1"), " userid='$id'"); setcookie('user_' . $id, 'watched', time() + 3600); } } break; case 't': case 'topic': { if (!isset($_COOKIE['topic_' . $id])) { $db->update(tbl("group_topics"), array("total_views"), array("|f|total_views+1"), " topic_id='$id'"); setcookie('topic_' . $id, 'watched', time() + 3600); } } break; break; case 'g': case 'group': { if (!isset($_COOKIE['group_' . $id])) { $db->update(tbl("groups"), array("total_views"), array("|f|total_views+1"), " group_id='$id'"); setcookie('group_' . $id, 'watched', time() + 3600); } } break; case "c": case "collect": case "collection": { if (!isset($_COOKIE['collection_' . $id])) { $db->update(tbl("collections"), array("views"), array("|f|views+1"), " collection_id = '$id'"); setcookie('collection_' . $id, 'viewed', time() + 3600); } } break; case "photos": case "photo": case "p": { if (!isset($_COOKIE['photo_' . $id])) { $db->update(tbl('photos'), array("views", "last_viewed"), array("|f|views+1", NOW()), " photo_id = '$id'"); setcookie('photo_' . $id, 'viewed', time() + 3600); } } } } function cbdate($format = NULL, $timestamp = NULL) { if (!$format) { $format = config("datE_format"); } if (!$timestamp) return date($format); else return date($format, $timestamp); } /** * Function used to count pages * @param TOTAL RESULTS NUM * @param NUMBER OF RESULTS to DISPLAY NUM */ function count_pages($total, $count) { if ($count < 1) $count = 1; $records = $total / $count; return $total_pages = round($records + 0.49, 0); } /** * This function used to check * weather user is online or not * @param : last_active time * @param : time margin */ function is_online($time, $margin = '5') { $margin = $margin * 60; $active = strtotime($time); $curr = time(); $diff = $curr - $active; if ($diff > $margin) return 'offline'; else return 'online'; } /** * Function used to check time span * A time difference function that outputs the * time passed in facebook's style: 1 day ago, * or 4 months ago. I took andrew dot * macrobert at gmail dot com function * and tweaked it a bit. On a strict enviroment * it was throwing errors, plus I needed it to * calculate the difference in time between * a past date and a future date. * thanks to yasmary at gmail dot com */ function nicetime($date, $istime = false) { if (empty($date)) { return lang('no_date_provided'); } $periods = array(lang("second"), lang("minute"), lang("hour"), lang("day"), lang("week"), lang("month"), lang("year"), lang("decade")); $lengths = array(lang("60"), lang("60"), lang("24"), lang("7"), lang("4.35"), lang("12"), lang("10")); $now = time(); if (!$istime) $unix_date = strtotime($date); else $unix_date = $date; // check validity of date if (empty($unix_date) || $unix_date < 1) { return lang("bad_date"); } // is it future date or past date if ($now > $unix_date) { //time_ago $difference = $now - $unix_date; $tense = "time_ago"; } else { //from_now $difference = $unix_date - $now; $tense = "a moment ago"; } for ($j = 0; $difference >= $lengths[$j] && $j < count($lengths) - 1; $j++) { $difference /= $lengths[$j]; } $difference = round($difference); if ($difference != 1) { $periods[$j].= "s"; } return sprintf(lang($tense), $difference, $periods[$j]); } /** * Function used to format outgoing link */ function outgoing_link($out) { preg_match("/http/", $out, $matches); if (empty($matches[0])) $out = "http://" . $out; return '' . $out . ''; } /** * Function used to get country via country code */ function get_country($code) { global $db; $result = $db->select(tbl("countries"), "name_en,iso2", " iso2='$code' OR iso3='$code'"); if ($db->num_rows > 0) { $flag = ''; $result = $result[0]; if (SHOW_COUNTRY_FLAG) $flag = '
$array = file('one file.txt');
* $isUTF8 = isUTF8($array);
* if (!$isUTF8) --> we need to apply utf8_encode() to be in UTF8
* else --> we are in UTF8 :)
*
* @param mixed A string, or an array from a file() function.
* @return boolean
*/
function isUTF8($string)
{
if (is_array($string))
{
$enc = implode('', $string);
return @!((ord($enc[0]) != 239) && (ord($enc[1]) != 187) && (ord($enc[2]) != 191));
}
else
{
return (utf8_encode(utf8_decode($string)) == $string);
}
}
/*
extract the file extension from any given path or url.
source: http://www.php.net/manual/en/function.basename.php#89127
*/
function fetch_file_extension($filepath)
{
preg_match('/[^?]*/', $filepath, $matches);
$string = $matches[0];
$pattern = preg_split('/\./', $string, -1, PREG_SPLIT_OFFSET_CAPTURE);
# check if there is any extension
if (count($pattern) == 1)
{
// no file extension found
return;
}
if (count($pattern) > 1)
{
$filenamepart = $pattern[count($pattern) - 1][0];
preg_match('/[^?]*/', $filenamepart, $matches);
return $matches[0];
}
}
/*
extract the file filename from any given path or url.
source: http://www.php.net/manual/en/function.basename.php#89127
*/
function fetch_filename($filepath)
{
preg_match('/[^?]*/', $filepath, $matches);
$string = $matches[0];
#split the string by the literal dot in the filename
$pattern = preg_split('/\./', $string, -1, PREG_SPLIT_OFFSET_CAPTURE);
#get the last dot position
$lastdot = $pattern[count($pattern) - 1][1];
#now extract the filename using the basename function
$filename = basename(substr($string, 0, $lastdot - 1));
#return the filename part
return $filename;
}
/**
* Function used to generate
* embed code of embedded video
*/
function embeded_code($vdetails)
{
$code = '';
$code .= '';
return $code;
}
/**
* function used to convert input to proper date created formate
*/
function datecreated($in)
{
$date_els = explode('-', $in);
//checking date format
$df = config("date_format");
$df_els = explode('-', $df);
foreach ($df_els as $key => $el)
${strtolower($el) . 'id'} = $key;
$month = $date_els[$mid];
$day = $date_els[$did];
$year = $date_els[$yid];
if ($in)
return date("Y-m-d", strtotime($year . '-' . $month . '-' . $day));
else
return '0000-00-00';
}
/**
* After struggling alot with baseurl problem
* i finally able to found its nice and working solkution..
* its not my original but its a genuine working copy
* its still in beta mode
*/
function baseurl()
{
$protocol = is_ssl() ? 'https://' : 'http://';
if (!$sub_dir)
return $base = $protocol . $_SERVER['HTTP_HOST'] . untrailingslashit(stripslashes(dirname(($_SERVER['SCRIPT_NAME']))));
else
return $base = $protocol . $_SERVER['HTTP_HOST'] . untrailingslashit(stripslashes(dirname(dirname($_SERVER['SCRIPT_NAME']))));
}
function base_url()
{
return baseurl();
}
/**
* SRC (WORD PRESS)
* Appends a trailing slash.
*
* Will remove trailing slash if it exists already before adding a trailing
* slash. This prevents double slashing a string or path.
*
* The primary use of this is for paths and thus should be used for paths. It is
* not restricted to paths and offers no specific path support.
*
* @since 1.2.0
* @uses untrailingslashit() Unslashes string if it was slashed already.
*
* @param string $string What to add the trailing slash to.
* @return string String with trailing slash added.
*/
function trailingslashit($string)
{
return untrailingslashit($string) . '/';
}
/**
* SRC (WORD PRESS)
* Removes trailing slash if it exists.
*
* The primary use of this is for paths and thus should be used for paths. It is
* not restricted to paths and offers no specific path support.
*
* @since 2.2.0
*
* @param string $string What to remove the trailing slash from.
* @return string String without the trailing slash.
*/
function untrailingslashit($string)
{
return rtrim($string, '/');
}
/**
* Determine if SSL is used.
*
* @since 2.6.0
*
* @return bool True if SSL, false if not used.
*/
function is_ssl()
{
if (isset($_SERVER['HTTPS']))
{
if ('on' == strtolower($_SERVER['HTTPS']))
return true;
if ('1' == $_SERVER['HTTPS'])
return true;
} elseif (isset($_SERVER['SERVER_PORT']) && ( '443' == $_SERVER['SERVER_PORT'] ))
{
return true;
}
return false;
}
/**
* This will update stats like Favorite count, Playlist count
*/
function updateObjectStats($type = 'favorite', $object = 'video', $id, $op = '+')
{
global $db;
switch ($type)
{
case "favorite": case "favourite":
case "favorites": case "favourties":
case "fav":
{
switch ($object)
{
case "video":
case "videos": case "v":
{
$db->update(tbl('video'), array('favourite_count'), array("|f|favourite_count" . $op . "1"), " videoid = '" . $id . "'");
}
break;
case "photo":
case "photos": case "p":
{
$db->update(tbl('photos'), array('total_favorites'), array("|f|total_favorites" . $op . "1"), " photo_id = '" . $id . "'");
}
break;
/* case "collection":
case "collections": case "cl":
{
$db->update(tbl('photos'),array('total_favorites'),array("|f|total_favorites".$op."1")," photo_id = '".$id."'");
}
break; */
}
}
break;
case "playlist": case "playList":
case "plist":
{
switch ($object)
{
case "video":
case "videos": case "v":
{
$db->update(tbl('video'), array('playlist_count'), array("|f|playlist_count" . $op . "1"), " videoid = '" . $id . "'");
}
}
}
}
}
/**
* FUnction used to check weather conversion lock exists or not
* if converson log exists it means no further conersion commands will be executed
*
* @return BOOLEAN
*/
function conv_lock_exists()
{
if (file_exists(TEMP_DIR . '/conv_lock.loc'))
return true;
else
return false;
}
/**
* Function used to return a well-formed queryString
* for passing variables to url
* @input variable_name
*/
function queryString($var = false, $remove = false)
{
$queryString = $_SERVER['QUERY_STRING'];
if ($var)
$queryString = preg_replace("/&?($var)=([\w+\s\b\.?\S])[^&]*/", "", $queryString);
if ($remove)
{
if (!is_array($remove))
$queryString = preg_replace("/&?($remove)=([\w+\s\b\.?\S])[^&]*/", "", $queryString);
else
foreach ($remove as $rm)
{
$queryString = preg_replace("/&?($rm)=([\w+\s\b\.?\S])[^&]*/", "", $queryString);
}
}
if ($queryString)
$preUrl = "?$queryString&";
else
$preUrl = "?";
$preUrl = preg_replace(array("/(\&{2,10})/", "/\?\&/"), array("&", "?"), $preUrl);
return $preUrl . $var;
}
/**
* Following two functions are taken from
* tutorialzine.com's post 'Creating a Facebook-like Registration Form with jQuery'
* These function are written by Martin Angelov.
* Read post here: http://tutorialzine.com/2009/08/creating-a-facebook-like-registration-form-with-jquery/
*/
function generate_options($params)
{
$reverse = false;
if ($params['from'] > $params['to'])
{
$tmp = $params['from'];
$params['from'] = $params['to'];
$params['to'] = $tmp;
$reverse = true;
}
$return_string = array();
for ($i = $params['from']; $i <= $params['to']; $i++)
{
//$return_string[$i] = ($callback?$callback($i):$i);
$return_string[] = '';
}
if ($reverse)
{
$return_string = array_reverse($return_string);
}
return join('', $return_string);
}
function callback_month($month)
{
return date('M', mktime(0, 0, 0, $month, 1));
}
/**
* Function use to download file to server
*
* @param URL
* @param destination
*/
function snatch_it($snatching_file, $destination, $dest_name, $rawdecode = true)
{
global $curl;
if ($rawdecode == true)
$snatching_file = rawurldecode($snatching_file);
$destination . '/' . $dest_name;
$fp = fopen($destination . '/' . $dest_name, 'w+');
$ch = curl_init($snatching_file);
curl_setopt($ch, CURLOPT_TIMEOUT, 600);
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.2) Gecko/20070219 Firefox/2.0.0.2');
curl_exec($ch);
curl_close($ch);
fclose($fp);
}
/**
* Function check curl
*/
function isCurlInstalled()
{
if (in_array('curl', get_loaded_extensions()))
{
return true;
}
else
{
return false;
}
}
/**
* Function for loading
* uploader file url & other configurations
*/
function uploaderDetails()
{
global $uploaderType;
$uploaderDetails = array
(
'uploadSwfPath' => JS_URL . '/uploadify/uploadify.swf',
'uploadScriptPath' => BASEURL . '/actions/file_uploader.php',
);
$photoUploaderDetails = array
(
'uploadSwfPath' => JS_URL . '/uploadify/uploadify.swf',
'uploadScriptPath' => BASEURL . '/actions/photo_uploader.php',
);
assign('uploaderDetails', $uploaderDetails);
assign('photoUploaderDetails', $photoUploaderDetails);
//Calling Custom Functions
cb_call_functions('uploaderDetails');
}
/**
* Function isSectionEnabled
* This function used to check weather INPUT section is enabled or not
*/
function isSectionEnabled($input, $restrict = false)
{
global $Cbucket;
$section = $Cbucket->configs[$input . 'Section'];
if (!$restrict)
{
if ($section == 'yes')
return true;
else
return false;
}else
{
if ($section == 'yes' || THIS_PAGE == 'cb_install')
{
return true;
}
else
{
template_files('blocked.html');
display_it();
exit();
}
}
}
function array_depth($array)
{
$ini_depth = 0;
foreach ($array as $arr)
{
if (is_array($arr))
{
$depth = array_depth($arr) + 1;
if ($depth > $ini_depth)
$ini_depth = $depth;
}
}
return $ini_depth;
}
/**
* JSON_ENCODE short
*/
function je($in)
{
return json_encode($in);
}
/**
* JSON_DECODE short
*/
function jd($in, $returnClass = false)
{
if (!$returnClass)
return json_decode($in, true); else
return json_decode($in);
}
/**
* function used to update last commented option
* so comment cache can be refreshed
*/
function update_last_commented($type, $id)
{
global $db;
if ($type && $id)
{
switch ($type)
{
case "v":
case "video":
case "vdo":
case "vid":
case "videos":
$db->update(tbl("video"), array('last_commented'), array(now()), "videoid='$id'");
break;
case "c":
case "channel":
case "user":
case "u":
case "users":
case "channels":
$db->update(tbl("users"), array('last_commented'), array(now()), "userid='$id'");
break;
case "cl":
case "collection":
case "collect":
case "collections":
case "collects":
$db->update(tbl("collections"), array('last_commented'), array(now()), "collection_id='$id'");
break;
case "p":
case "photo":
case "photos":
case "picture":
case "pictures":
$db->update(tbl("photos"), array('last_commented'), array(now()), "photo_id='$id'");
break;
case "t":
case "topic":
case "topics":
$db->update(tbl("group_topics"), array('last_post_time'), array(now()), "topic_id='$id'");
break;
}
}
}
/**
* Function used to create user feed
* this function simple takes ID as input
* and do the rest seemlessli ;)
*/
function addFeed($array)
{
global $cbfeeds, $cbphoto, $userquery;
$action = $array['action'];
if ($array['uid'])
$userid = $array['uid'];
else
$userid = userid();
switch ($action)
{
case "upload_photo":
{
$feed['action'] = 'upload_photo';
$feed['object'] = 'photo';
$feed['object_id'] = $array['object_id'];
$feed['uid'] = $userid;
;
$cbfeeds->addFeed($feed);
}
break;
case "upload_video":
case "add_favorite":
{
$feed['action'] = $action;
$feed['object'] = 'video';
$feed['object_id'] = $array['object_id'];
$feed['uid'] = $userid;
$cbfeeds->addFeed($feed);
}
break;
case "signup":
{
$feed['action'] = 'signup';
$feed['object'] = 'signup';
$feed['object_id'] = $array['object_id'];
$feed['uid'] = $userid;
;
$cbfeeds->addFeed($feed);
}
break;
case "create_group":
case "join_group":
{
$feed['action'] = $action;
$feed['object'] = 'group';
$feed['object_id'] = $array['object_id'];
$feed['uid'] = $userid;
$cbfeeds->addFeed($feed);
}
break;
case "add_friend":
{
$feed['action'] = 'add_friend';
$feed['object'] = 'friend';
$feed['object_id'] = $array['object_id'];
$feed['uid'] = $userid;
$cbfeeds->addFeed($feed);
}
break;
case "add_collection":
{
$feed['action'] = 'add_collection';
$feed['object'] = 'collection';
$feed['object_id'] = $array['object_id'];
$feed['uid'] = $userid;
$cbfeeds->addFeed($feed);
}
}
}
/**
* function used to get plugin directory name
*/
function this_plugin($pluginFile = NULL)
{
if (!$pluginFile)
global $pluginFile;
return basename(dirname($pluginFile));
}
/**
* function used to get user agent details
* Thanks to ruudrp at live dot nl 28-Nov-2010 11:31 PHP.NET
*/
function get_browser_details($in = NULL, $assign = false)
{
//Checking if browser is firefox
if (!$in)
$in = $_SERVER['HTTP_USER_AGENT'];
$u_agent = $in;
$bname = 'Unknown';
$platform = 'Unknown';
$version = "";
//First get the platform?
if (preg_match('/linux/i', $u_agent))
{
$platform = 'linux';
}
elseif (preg_match('/iPhone/i', $u_agent))
{
$platform = 'iphone';
}
elseif (preg_match('/iPad/i', $u_agent))
{
$platform = 'ipad';
}
elseif (preg_match('/macintosh|mac os x/i', $u_agent))
{
$platform = 'mac';
}
elseif (preg_match('/windows|win32/i', $u_agent))
{
$platform = 'windows';
}
if (preg_match('/Android/i', $u_agent))
{
$platform = 'android';
}
// Next get the name of the useragent yes seperately and for good reason
if (preg_match('/MSIE/i', $u_agent) && !preg_match('/Opera/i', $u_agent))
{
$bname = 'Internet Explorer';
$ub = "MSIE";
}
elseif (preg_match('/Firefox/i', $u_agent))
{
$bname = 'Mozilla Firefox';
$ub = "Firefox";
}
elseif (preg_match('/Chrome/i', $u_agent))
{
$bname = 'Google Chrome';
$ub = "Chrome";
}
elseif (preg_match('/Safari/i', $u_agent))
{
$bname = 'Apple Safari';
$ub = "Safari";
}
elseif (preg_match('/Opera/i', $u_agent))
{
$bname = 'Opera';
$ub = "Opera";
}
elseif (preg_match('/Netscape/i', $u_agent))
{
$bname = 'Netscape';
$ub = "Netscape";
}
elseif (preg_match('/Googlebot/i', $u_agent))
{
$bname = 'Googlebot';
$ub = "bot";
}
elseif (preg_match('/msnbot/i', $u_agent))
{
$bname = 'MSNBot';
$ub = "bot";
}
elseif (preg_match('/Yahoo\! Slurp/i', $u_agent))
{
$bname = 'Yahoo Slurp';
$ub = "bot";
}
// finally get the correct version number
$known = array('Version', $ub, 'other');
$pattern = '#(?