2003-04-21 17:37:11 -04:00
< ? php
2004-10-11 09:22:33 -04:00
require_once ( dirname ( __FILE__ ) . '/functions-compat.php' );
2003-04-21 17:37:11 -04:00
if ( ! function_exists ( '_' )) {
function _ ( $string ) {
return $string ;
}
}
2004-08-06 21:22:17 -04:00
function get_profile ( $field , $user = false ) {
global $wpdb ;
if ( ! $user )
2005-07-18 16:12:48 -04:00
$user = $wpdb -> escape ( $_COOKIE [ USER_COOKIE ]);
2004-08-06 21:22:17 -04:00
return $wpdb -> get_var ( " SELECT $field FROM $wpdb->users WHERE user_login = ' $user ' " );
}
2005-02-20 23:19:43 -05:00
function mysql2date ( $dateformatstring , $mysqlstring , $translate = true ) {
2004-11-25 11:23:24 -05:00
global $month , $weekday , $month_abbrev , $weekday_abbrev ;
2003-04-21 17:37:11 -04:00
$m = $mysqlstring ;
if ( empty ( $m )) {
return false ;
}
$i = mktime ( substr ( $m , 11 , 2 ), substr ( $m , 14 , 2 ), substr ( $m , 17 , 2 ), substr ( $m , 5 , 2 ), substr ( $m , 8 , 2 ), substr ( $m , 0 , 4 ));
2005-02-20 23:19:43 -05:00
if ( ! empty ( $month ) && ! empty ( $weekday ) && $translate ) {
2003-04-21 17:37:11 -04:00
$datemonth = $month [ date ( 'm' , $i )];
2004-11-25 11:23:24 -05:00
$datemonth_abbrev = $month_abbrev [ $datemonth ];
2003-04-21 17:37:11 -04:00
$dateweekday = $weekday [ date ( 'w' , $i )];
2004-11-25 11:23:24 -05:00
$dateweekday_abbrev = $weekday_abbrev [ $dateweekday ];
2003-04-21 17:37:11 -04:00
$dateformatstring = ' ' . $dateformatstring ;
2004-11-25 11:23:24 -05:00
$dateformatstring = preg_replace ( " /([^ \\ \ ])D/ " , " \\ 1 " . backslashit ( $dateweekday_abbrev ), $dateformatstring );
2003-04-21 17:37:11 -04:00
$dateformatstring = preg_replace ( " /([^ \\ \ ])F/ " , " \\ 1 " . backslashit ( $datemonth ), $dateformatstring );
$dateformatstring = preg_replace ( " /([^ \\ \ ])l/ " , " \\ 1 " . backslashit ( $dateweekday ), $dateformatstring );
2004-11-25 11:23:24 -05:00
$dateformatstring = preg_replace ( " /([^ \\ \ ])M/ " , " \\ 1 " . backslashit ( $datemonth_abbrev ), $dateformatstring );
2003-04-21 17:37:11 -04:00
$dateformatstring = substr ( $dateformatstring , 1 , strlen ( $dateformatstring ) - 1 );
}
$j = @ date ( $dateformatstring , $i );
if ( ! $j ) {
2003-11-14 13:55:41 -05:00
// for debug purposes
// echo $i." ".$mysqlstring;
2003-04-21 17:37:11 -04:00
}
return $j ;
}
2004-03-24 21:21:40 -05:00
function current_time ( $type , $gmt = 0 ) {
2003-11-15 03:58:18 -05:00
switch ( $type ) {
case 'mysql' :
2004-04-24 17:52:24 -04:00
if ( $gmt ) $d = gmdate ( 'Y-m-d H:i:s' );
else $d = gmdate ( 'Y-m-d H:i:s' , ( time () + ( get_settings ( 'gmt_offset' ) * 3600 )));
return $d ;
2003-11-15 03:58:18 -05:00
break ;
case 'timestamp' :
2004-04-24 17:52:24 -04:00
if ( $gmt ) $d = time ();
else $d = time () + ( get_settings ( 'gmt_offset' ) * 3600 );
return $d ;
2003-11-15 03:58:18 -05:00
break ;
}
}
2003-04-21 17:37:11 -04:00
function date_i18n ( $dateformatstring , $unixtimestamp ) {
2005-04-02 14:51:12 -05:00
global $month , $weekday , $month_abbrev , $weekday_abbrev ;
2003-04-21 17:37:11 -04:00
$i = $unixtimestamp ;
if (( ! empty ( $month )) && ( ! empty ( $weekday ))) {
$datemonth = $month [ date ( 'm' , $i )];
2005-04-02 14:51:12 -05:00
$datemonth_abbrev = $month_abbrev [ $datemonth ];
2003-04-21 17:37:11 -04:00
$dateweekday = $weekday [ date ( 'w' , $i )];
2005-04-02 14:51:12 -05:00
$dateweekday_abbrev = $weekday_abbrev [ $dateweekday ];
2003-04-21 17:37:11 -04:00
$dateformatstring = ' ' . $dateformatstring ;
2005-04-02 14:51:12 -05:00
$dateformatstring = preg_replace ( " /([^ \\ \ ])D/ " , " \\ 1 " . backslashit ( $dateweekday_abbrev ), $dateformatstring );
2003-04-21 17:37:11 -04:00
$dateformatstring = preg_replace ( " /([^ \\ \ ])F/ " , " \\ 1 " . backslashit ( $datemonth ), $dateformatstring );
$dateformatstring = preg_replace ( " /([^ \\ \ ])l/ " , " \\ 1 " . backslashit ( $dateweekday ), $dateformatstring );
2005-04-02 14:51:12 -05:00
$dateformatstring = preg_replace ( " /([^ \\ \ ])M/ " , " \\ 1 " . backslashit ( $datemonth_abbrev ), $dateformatstring );
2003-04-21 17:37:11 -04:00
$dateformatstring = substr ( $dateformatstring , 1 , strlen ( $dateformatstring ) - 1 );
}
$j = @ date ( $dateformatstring , $i );
return $j ;
}
function get_weekstartend ( $mysqlstring , $start_of_week ) {
$my = substr ( $mysqlstring , 0 , 4 );
$mm = substr ( $mysqlstring , 8 , 2 );
$md = substr ( $mysqlstring , 5 , 2 );
$day = mktime ( 0 , 0 , 0 , $md , $mm , $my );
$weekday = date ( 'w' , $day );
$i = 86400 ;
2005-04-10 16:07:46 -04:00
if ( $weekday < get_settings ( 'start_of_week' ))
$weekday = 7 - ( get_settings ( 'start_of_week' ) - $weekday );
2004-03-01 01:13:32 -05:00
while ( $weekday > get_settings ( 'start_of_week' )) {
2003-04-21 17:37:11 -04:00
$weekday = date ( 'w' , $day );
2005-04-10 16:07:46 -04:00
if ( $weekday < get_settings ( 'start_of_week' ))
$weekday = 7 - ( get_settings ( 'start_of_week' ) - $weekday );
2003-04-21 17:37:11 -04:00
$day = $day - 86400 ;
$i = 0 ;
}
$week [ 'start' ] = $day + 86400 - $i ;
2005-04-10 16:07:46 -04:00
//$week['end'] = $day - $i + 691199;
$week [ 'end' ] = $week [ 'start' ] + 604799 ;
2003-06-07 13:19:38 -04:00
return $week ;
2003-04-21 17:37:11 -04:00
}
2004-02-28 12:51:41 -05:00
function get_lastpostdate ( $timezone = 'server' ) {
2004-05-24 04:22:18 -04:00
global $cache_lastpostdate , $pagenow , $wpdb ;
2004-02-28 12:51:41 -05:00
$add_seconds_blog = get_settings ( 'gmt_offset' ) * 3600 ;
$add_seconds_server = date ( 'Z' );
2004-03-31 13:06:45 -05:00
$now = current_time ( 'mysql' , 1 );
2004-04-20 18:56:47 -04:00
if ( ! isset ( $cache_lastpostdate [ $timezone ]) ) {
2004-02-28 12:51:41 -05:00
switch ( strtolower ( $timezone )) {
case 'gmt' :
2004-05-24 04:22:18 -04:00
$lastpostdate = $wpdb -> get_var ( " SELECT post_date_gmt FROM $wpdb->posts WHERE post_date_gmt <= ' $now ' AND post_status = 'publish' ORDER BY post_date_gmt DESC LIMIT 1 " );
2004-02-28 12:51:41 -05:00
break ;
case 'blog' :
2004-05-24 04:22:18 -04:00
$lastpostdate = $wpdb -> get_var ( " SELECT post_date FROM $wpdb->posts WHERE post_date_gmt <= ' $now ' AND post_status = 'publish' ORDER BY post_date_gmt DESC LIMIT 1 " );
2004-02-28 12:51:41 -05:00
break ;
case 'server' :
2004-05-24 04:22:18 -04:00
$lastpostdate = $wpdb -> get_var ( " SELECT DATE_ADD(post_date_gmt, INTERVAL ' $add_seconds_server ' SECOND) FROM $wpdb->posts WHERE post_date_gmt <= ' $now ' AND post_status = 'publish' ORDER BY post_date_gmt DESC LIMIT 1 " );
2004-02-28 12:51:41 -05:00
break ;
}
$cache_lastpostdate [ $timezone ] = $lastpostdate ;
2003-04-21 17:37:11 -04:00
} else {
2004-02-28 12:51:41 -05:00
$lastpostdate = $cache_lastpostdate [ $timezone ];
2003-04-21 17:37:11 -04:00
}
2003-06-07 13:19:38 -04:00
return $lastpostdate ;
2003-04-21 17:37:11 -04:00
}
2004-02-28 12:51:41 -05:00
function get_lastpostmodified ( $timezone = 'server' ) {
2004-05-24 04:22:18 -04:00
global $cache_lastpostmodified , $pagenow , $wpdb ;
2004-02-28 12:51:41 -05:00
$add_seconds_blog = get_settings ( 'gmt_offset' ) * 3600 ;
$add_seconds_server = date ( 'Z' );
2004-03-31 13:06:45 -05:00
$now = current_time ( 'mysql' , 1 );
2004-04-20 18:56:47 -04:00
if ( ! isset ( $cache_lastpostmodified [ $timezone ]) ) {
2004-03-31 13:06:45 -05:00
switch ( strtolower ( $timezone )) {
2004-02-28 12:51:41 -05:00
case 'gmt' :
2004-05-24 04:22:18 -04:00
$lastpostmodified = $wpdb -> get_var ( " SELECT post_modified_gmt FROM $wpdb->posts WHERE post_modified_gmt <= ' $now ' AND post_status = 'publish' ORDER BY post_modified_gmt DESC LIMIT 1 " );
2004-02-28 12:51:41 -05:00
break ;
case 'blog' :
2004-05-24 04:22:18 -04:00
$lastpostmodified = $wpdb -> get_var ( " SELECT post_modified FROM $wpdb->posts WHERE post_modified_gmt <= ' $now ' AND post_status = 'publish' ORDER BY post_modified_gmt DESC LIMIT 1 " );
2004-02-28 12:51:41 -05:00
break ;
case 'server' :
2004-05-24 04:22:18 -04:00
$lastpostmodified = $wpdb -> get_var ( " SELECT DATE_ADD(post_modified_gmt, INTERVAL ' $add_seconds_server ' SECOND) FROM $wpdb->posts WHERE post_modified_gmt <= ' $now ' AND post_status = 'publish' ORDER BY post_modified_gmt DESC LIMIT 1 " );
2004-02-28 12:51:41 -05:00
break ;
}
$lastpostdate = get_lastpostdate ( $timezone );
if ( $lastpostdate > $lastpostmodified ) {
$lastpostmodified = $lastpostdate ;
}
$cache_lastpostmodified [ $timezone ] = $lastpostmodified ;
2004-02-21 22:28:46 -05:00
} else {
2004-02-28 12:51:41 -05:00
$lastpostmodified = $cache_lastpostmodified [ $timezone ];
2004-02-21 22:28:46 -05:00
}
return $lastpostmodified ;
}
2003-04-21 17:37:11 -04:00
function user_pass_ok ( $user_login , $user_pass ) {
2004-04-20 18:56:47 -04:00
global $cache_userdata ;
if ( empty ( $cache_userdata [ $user_login ]) ) {
2003-04-21 17:37:11 -04:00
$userdata = get_userdatabylogin ( $user_login );
} else {
$userdata = $cache_userdata [ $user_login ];
}
2004-02-19 17:42:47 -05:00
return ( md5 ( $user_pass ) == $userdata -> user_pass );
2003-04-21 17:37:11 -04:00
}
function get_usernumposts ( $userid ) {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2005-03-02 12:59:19 -05:00
return $wpdb -> get_var ( " SELECT COUNT(*) FROM $wpdb->posts WHERE post_author = ' $userid ' AND post_status = 'publish' " );
2003-04-21 17:37:11 -04:00
}
2005-06-27 18:02:57 -04:00
2003-11-14 13:55:41 -05:00
// examine a url (supposedly from this blog) and try to
// determine the post ID it represents.
2005-05-17 22:27:43 -04:00
function url_to_postid ( $url ) {
2005-05-13 22:59:42 -04:00
global $wp_rewrite ;
2003-11-14 13:55:41 -05:00
2005-06-27 18:02:57 -04:00
// First, check to see if there is a 'p=N' or 'page_id=N' to match against
2005-05-13 22:59:42 -04:00
preg_match ( '#[?&](p|page_id)=(\d+)#' , $url , $values );
$id = intval ( $values [ 2 ]);
if ( $id ) return $id ;
2003-11-14 13:55:41 -05:00
2005-06-27 18:02:57 -04:00
// Check to see if we are using rewrite rules
2005-05-13 22:59:42 -04:00
$rewrite = $wp_rewrite -> wp_rewrite_rules ();
2003-11-14 13:55:41 -05:00
2005-06-27 18:02:57 -04:00
// Not using rewrite rules, and 'p=N' and 'page_id=N' methods failed, so we're out of options
2005-05-13 22:59:42 -04:00
if ( empty ( $rewrite ) )
return 0 ;
2005-06-27 18:02:57 -04:00
// $url cleanup by Mark Jaquith
// This fixes things like #anchors, ?query=strings, missing 'www.',
// added 'www.', or added 'index.php/' that will mess up our WP_Query
// and return a false negative
// Get rid of the #anchor
$url_split = explode ( '#' , $url );
$url = $url_split [ 0 ];
// Get rid of URI ?query=string
$url_split = explode ( '?' , $url );
$url = $url_split [ 0 ];
// Add 'www.' if it is absent and should be there
if ( false !== strpos ( get_settings ( 'home' ), '://www.' ) && false === strpos ( $url , '://www.' ) )
$url = str_replace ( '://' , '://www.' , $url );
// Strip 'www.' if it is present and shouldn't be
if ( false === strpos ( get_settings ( 'home' ), '://www.' ) )
$url = str_replace ( '://www.' , '://' , $url );
// Strip 'index.php/' if we're not using path info permalinks
if ( false === strpos ( $rewrite , 'index.php/' ) )
$url = str_replace ( 'index.php/' , '' , $url );
2003-11-14 13:55:41 -05:00
2005-06-27 18:02:57 -04:00
// Chop off http://domain.com
if ( false !== strpos ( $url , get_settings ( 'home' )) ) {
$url = str_replace ( get_settings ( 'home' ), '' , $url );
2005-05-17 22:27:43 -04:00
} else {
2005-06-27 18:02:57 -04:00
// Chop off /path/to/blog
2005-05-17 22:27:43 -04:00
$home_path = parse_url ( get_settings ( 'home' ));
$home_path = $home_path [ 'path' ];
2005-06-27 18:02:57 -04:00
$url = str_replace ( $home_path , '' , $url );
2005-05-17 22:27:43 -04:00
}
2005-06-27 18:02:57 -04:00
// Trim leading and lagging slashes
$url = trim ( $url , '/' );
$request = $url ;
// Done with cleanup
2005-04-12 17:12:28 -04:00
2005-05-13 22:59:42 -04:00
// Look for matches.
$request_match = $request ;
foreach ( $rewrite as $match => $query ) {
// If the requesting file is the anchor of the match, prepend it
// to the path info.
2005-06-27 18:02:57 -04:00
if (( ! empty ( $url )) && ( strpos ( $match , $url ) === 0 )) {
$request_match = $url . '/' . $request ;
2005-05-13 22:59:42 -04:00
}
2004-09-27 08:41:39 -04:00
2005-05-13 22:59:42 -04:00
if ( preg_match ( " !^ $match ! " , $request_match , $matches )) {
// Got a match.
// Trim the query of everything up to the '?'.
$query = preg_replace ( " !^.+ \ ?! " , '' , $query );
// Substitute the substring matches into the query.
eval ( " \$ query = \" $query\ " ; " );
$query = new WP_Query ( $query );
2005-08-30 00:07:12 -04:00
if ( $query -> is_single || $query -> is_page )
2005-05-13 22:59:42 -04:00
return $query -> post -> ID ;
else
return 0 ;
}
2005-04-12 17:12:28 -04:00
}
2003-12-22 18:00:45 -05:00
2005-05-13 22:59:42 -04:00
return 0 ;
2003-11-14 13:55:41 -05:00
}
2003-10-25 20:19:23 -04:00
/* Options functions */
2003-04-21 17:37:11 -04:00
function get_settings ( $setting ) {
2004-09-29 16:33:05 -04:00
global $wpdb , $cache_settings , $cache_nonexistantoptions ;
2005-03-18 01:07:36 -05:00
if ( strstr ( $_SERVER [ 'REQUEST_URI' ], 'wp-admin/install.php' ) || defined ( 'WP_INSTALLING' ) )
2004-02-08 11:10:28 -05:00
return false ;
2004-02-16 23:56:29 -05:00
2004-06-10 06:01:45 -04:00
if ( empty ( $cache_settings ) )
2004-06-10 04:42:25 -04:00
$cache_settings = get_alloptions ();
2004-02-16 23:56:29 -05:00
2004-09-29 16:33:05 -04:00
if ( empty ( $cache_nonexistantoptions ) )
$cache_nonexistantoptions = array ();
2004-06-30 17:54:10 -04:00
if ( 'home' == $setting && '' == $cache_settings -> home )
2005-01-27 13:39:52 -05:00
return apply_filters ( 'option_' . $setting , $cache_settings -> siteurl );
2004-04-28 03:27:03 -04:00
2004-07-23 05:26:37 -04:00
if ( isset ( $cache_settings -> $setting ) ) :
2005-01-27 13:39:52 -05:00
return apply_filters ( 'option_' . $setting , $cache_settings -> $setting );
2004-07-23 05:26:37 -04:00
else :
2004-09-29 16:33:05 -04:00
// for these cases when we're asking for an unknown option
if ( isset ( $cache_nonexistantoptions [ $setting ]) )
return false ;
2004-07-23 05:26:37 -04:00
$option = $wpdb -> get_var ( " SELECT option_value FROM $wpdb->options WHERE option_name = ' $setting ' " );
2004-09-29 16:33:05 -04:00
if ( ! $option ) :
2004-09-29 20:34:46 -04:00
$cache_nonexistantoptions [ $setting ] = true ;
2004-09-29 16:33:05 -04:00
return false ;
endif ;
2004-11-28 14:53:11 -05:00
@ $kellogs = unserialize ( $option );
if ( $kellogs !== FALSE )
2005-01-27 13:39:52 -05:00
return apply_filters ( 'option_' . $setting , $kellogs );
else return apply_filters ( 'option_' . $setting , $option );
2004-07-23 05:26:37 -04:00
endif ;
2003-04-21 17:37:11 -04:00
}
2004-09-04 20:24:28 -04:00
function get_option ( $option ) {
return get_settings ( $option );
}
2005-08-07 15:23:41 -04:00
function get_user_option ( $option ) {
global $wpdb , $current_user ;
if ( isset ( $current_user -> data -> { $wpdb -> prefix . $option } ) ) // Blog specific
return $current_user -> data -> { $wpdb -> prefix . $option };
elseif ( isset ( $current_user -> data -> { $option } ) ) // User specific and cross-blog
return $current_user -> data -> { $option };
else // Blog global
return get_option ( $option );
}
2004-09-04 20:24:28 -04:00
function form_option ( $option ) {
2004-12-12 15:41:19 -05:00
echo htmlspecialchars ( get_option ( $option ), ENT_QUOTES );
2004-09-04 20:24:28 -04:00
}
2003-06-12 18:45:08 -04:00
function get_alloptions () {
2004-10-08 15:49:58 -04:00
global $wpdb , $wp_queries ;
$wpdb -> hide_errors ();
if ( ! $options = $wpdb -> get_results ( " SELECT option_name, option_value FROM $wpdb->options WHERE autoload = 'yes' " )) {
$options = $wpdb -> get_results ( " SELECT option_name, option_value FROM $wpdb->options " );
}
$wpdb -> show_errors ();
foreach ( $options as $option ) {
// "When trying to design a foolproof system,
// never underestimate the ingenuity of the fools :)" -- Dougal
if ( 'siteurl' == $option -> option_name ) $option -> option_value = preg_replace ( '|/+$|' , '' , $option -> option_value );
if ( 'home' == $option -> option_name ) $option -> option_value = preg_replace ( '|/+$|' , '' , $option -> option_value );
if ( 'category_base' == $option -> option_name ) $option -> option_value = preg_replace ( '|/+$|' , '' , $option -> option_value );
2004-11-28 14:53:11 -05:00
@ $value = unserialize ( $option -> option_value );
if ( $value === FALSE )
$value = $option -> option_value ;
2005-01-27 13:39:52 -05:00
$all_options -> { $option -> option_name } = apply_filters ( 'pre_option_' . $option -> option_name , $value );
2004-02-16 23:56:29 -05:00
}
2005-01-27 13:39:52 -05:00
return apply_filters ( 'all_options' , $all_options );
2003-06-12 18:45:08 -04:00
}
2003-10-25 20:19:23 -04:00
function update_option ( $option_name , $newvalue ) {
2004-05-24 04:22:18 -04:00
global $wpdb , $cache_settings ;
2004-07-23 05:14:30 -04:00
2005-07-17 14:41:11 -04:00
if ( is_string ( $newvalue ) )
$newvalue = trim ( $newvalue );
2005-07-16 17:13:14 -04:00
// If the new and old values are the same, no need to update.
if ( $newvalue == get_option ( $option_name ) )
return true ;
if ( is_array ( $newvalue ) || is_object ( $newvalue ) )
$newvalue = serialize ( $newvalue );
2004-06-23 21:00:31 -04:00
2004-12-18 21:30:40 -05:00
// If it's not there add it
if ( ! $wpdb -> get_var ( " SELECT option_name FROM $wpdb->options WHERE option_name = ' $option_name ' " ) )
add_option ( $option_name );
2004-04-22 17:29:59 -04:00
$newvalue = $wpdb -> escape ( $newvalue );
2005-07-16 17:13:14 -04:00
$option_name = $wpdb -> escape ( $option_name );
2004-05-24 04:22:18 -04:00
$wpdb -> query ( " UPDATE $wpdb->options SET option_value = ' $newvalue ' WHERE option_name = ' $option_name ' " );
2004-03-25 02:21:00 -05:00
$cache_settings = get_alloptions (); // Re cache settings
return true ;
2003-10-25 20:19:23 -04:00
}
2005-08-07 15:23:41 -04:00
function update_user_option ( $user_id , $option_name , $newvalue , $global = false ) {
global $wpdb ;
if ( ! $global )
$option_name = $wpdb -> prefix . $option_name ;
return update_usermeta ( $user_id , $option_name , $newvalue );
}
2004-04-16 17:17:09 -04:00
// thx Alex Stapleton, http://alex.vort-x.net/blog/
2004-12-18 21:30:40 -05:00
function add_option ( $name , $value = '' , $description = '' , $autoload = 'yes' ) {
2005-09-08 17:08:48 -04:00
global $wpdb , $cache_settings ;
// Make sure the option doesn't already exist
if ( isset ( $cache_settings -> $name ) )
return ;
2005-01-06 05:07:52 -05:00
$original = $value ;
2004-07-23 05:14:30 -04:00
if ( is_array ( $value ) || is_object ( $value ) )
$value = serialize ( $value );
2004-09-04 21:22:17 -04:00
if ( ! $wpdb -> get_var ( " SELECT option_name FROM $wpdb->options WHERE option_name = ' $name ' " ) ) {
2004-04-16 17:17:09 -04:00
$name = $wpdb -> escape ( $name );
$value = $wpdb -> escape ( $value );
2004-09-04 20:24:28 -04:00
$description = $wpdb -> escape ( $description );
2004-12-18 21:30:40 -05:00
$wpdb -> query ( " INSERT INTO $wpdb->options (option_name, option_value, option_description, autoload) VALUES (' $name ', ' $value ', ' $description ', ' $autoload ') " );
2004-04-16 17:17:09 -04:00
2004-04-20 18:56:47 -04:00
if ( $wpdb -> insert_id ) {
2004-04-16 17:17:09 -04:00
global $cache_settings ;
2005-01-06 05:07:52 -05:00
$cache_settings -> { $name } = $original ;
2004-04-16 17:17:09 -04:00
}
}
return ;
2003-10-25 20:19:23 -04:00
}
2004-04-24 17:21:19 -04:00
function delete_option ( $name ) {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-04-24 17:21:19 -04:00
// Get the ID, if no ID then return
2004-05-24 04:22:18 -04:00
$option_id = $wpdb -> get_var ( " SELECT option_id FROM $wpdb->options WHERE option_name = ' $name ' " );
2004-04-24 17:21:19 -04:00
if ( ! $option_id ) return false ;
2004-05-24 04:22:18 -04:00
$wpdb -> query ( " DELETE FROM $wpdb->options WHERE option_name = ' $name ' " );
2004-04-24 17:21:19 -04:00
return true ;
}
2004-09-26 20:45:53 -04:00
function add_post_meta ( $post_id , $key , $value , $unique = false ) {
global $wpdb ;
if ( $unique ) {
if ( $wpdb -> get_var ( " SELECT meta_key FROM $wpdb->postmeta WHERE meta_key
= '$key' AND post_id = '$post_id' " ) ) {
return false ;
}
}
$wpdb -> query ( " INSERT INTO $wpdb->postmeta
( post_id , meta_key , meta_value )
VALUES ( '$post_id' , '$key' , '$value' )
" );
return true ;
}
function delete_post_meta ( $post_id , $key , $value = '' ) {
global $wpdb ;
if ( empty ( $value )) {
$meta_id = $wpdb -> get_var ( " SELECT meta_id FROM $wpdb->postmeta WHERE
post_id = '$post_id' AND meta_key = '$key' " );
} else {
$meta_id = $wpdb -> get_var ( " SELECT meta_id FROM $wpdb->postmeta WHERE
post_id = '$post_id' AND meta_key = '$key' AND meta_value = '$value' " );
}
if ( ! $meta_id ) return false ;
if ( empty ( $value )) {
$wpdb -> query ( " DELETE FROM $wpdb->postmeta WHERE post_id = ' $post_id '
AND meta_key = '$key' " );
} else {
$wpdb -> query ( " DELETE FROM $wpdb->postmeta WHERE post_id = ' $post_id '
AND meta_key = '$key' AND meta_value = '$value' " );
}
return true ;
}
2004-10-06 01:11:11 -04:00
function get_post_meta ( $post_id , $key , $single = false ) {
2004-09-26 20:45:53 -04:00
global $wpdb , $post_meta_cache ;
if ( isset ( $post_meta_cache [ $post_id ][ $key ])) {
2004-10-06 01:11:11 -04:00
if ( $single ) {
return $post_meta_cache [ $post_id ][ $key ][ 0 ];
} else {
return $post_meta_cache [ $post_id ][ $key ];
}
2004-09-26 20:45:53 -04:00
}
$metalist = $wpdb -> get_results ( " SELECT meta_value FROM $wpdb->postmeta WHERE post_id = ' $post_id ' AND meta_key = ' $key ' " , ARRAY_N );
$values = array ();
if ( $metalist ) {
foreach ( $metalist as $metarow ) {
$values [] = $metarow [ 0 ];
}
}
2004-10-06 01:11:11 -04:00
if ( $single ) {
if ( count ( $values )) {
return $values [ 0 ];
} else {
return '' ;
}
} else {
return $values ;
}
2004-09-26 20:45:53 -04:00
}
function update_post_meta ( $post_id , $key , $value , $prev_value = '' ) {
global $wpdb , $post_meta_cache ;
2004-10-06 01:11:11 -04:00
if ( ! $wpdb -> get_var ( " SELECT meta_key FROM $wpdb->postmeta WHERE meta_key
= '$key' AND post_id = '$post_id' " ) ) {
return false ;
}
2004-09-26 20:45:53 -04:00
if ( empty ( $prev_value )) {
$wpdb -> query ( " UPDATE $wpdb->postmeta SET meta_value = ' $value ' WHERE
meta_key = '$key' AND post_id = '$post_id' " );
} else {
$wpdb -> query ( " UPDATE $wpdb->postmeta SET meta_value = ' $value ' WHERE
meta_key = '$key' AND post_id = '$post_id' AND meta_value = '$prev_value' " );
}
return true ;
}
2005-04-09 13:25:47 -04:00
// Deprecated. Use get_post().
2003-04-21 17:37:11 -04:00
function get_postdata ( $postid ) {
2005-04-09 13:25:47 -04:00
$post = & get_post ( $postid );
2003-05-29 10:04:30 -04:00
$postdata = array (
2005-04-09 13:25:47 -04:00
'ID' => $post -> ID ,
'Author_ID' => $post -> post_author ,
'Date' => $post -> post_date ,
'Content' => $post -> post_content ,
'Excerpt' => $post -> post_excerpt ,
'Title' => $post -> post_title ,
'Category' => $post -> post_category ,
'post_status' => $post -> post_status ,
'comment_status' => $post -> comment_status ,
'ping_status' => $post -> ping_status ,
'post_password' => $post -> post_password ,
'to_ping' => $post -> to_ping ,
'pinged' => $post -> pinged ,
'post_name' => $post -> post_name
2003-05-29 10:04:30 -04:00
);
2005-04-09 13:25:47 -04:00
2003-06-07 13:19:38 -04:00
return $postdata ;
2003-04-21 17:37:11 -04:00
}
2005-03-27 15:45:01 -05:00
// Retrieves post data given a post ID or post object.
// Handles post caching.
function & get_post ( & $post , $output = OBJECT ) {
global $post_cache , $wpdb ;
if ( empty ( $post ) ) {
if ( isset ( $GLOBALS [ 'post' ]) )
2005-06-26 15:55:12 -04:00
$_post = & $GLOBALS [ 'post' ];
2005-03-27 15:45:01 -05:00
else
2005-06-26 15:55:12 -04:00
$_post = null ;
2005-03-27 15:45:01 -05:00
} elseif ( is_object ( $post ) ) {
if ( ! isset ( $post_cache [ $post -> ID ]))
$post_cache [ $post -> ID ] = & $post ;
2005-06-26 15:55:12 -04:00
$_post = & $post_cache [ $post -> ID ];
2005-03-27 15:45:01 -05:00
} else {
2005-03-28 22:33:56 -05:00
if ( isset ( $post_cache [ $post ]))
2005-06-26 15:55:12 -04:00
$_post = & $post_cache [ $post ];
2005-03-27 15:45:01 -05:00
else {
2005-06-26 16:44:58 -04:00
$query = " SELECT * FROM $wpdb->posts WHERE ID = ' $post ' " ;
2005-03-27 15:45:01 -05:00
$post_cache [ $post ] = & $wpdb -> get_row ( $query );
2005-06-26 15:55:12 -04:00
$_post = & $post_cache [ $post ];
2003-04-21 17:37:11 -04:00
}
}
2005-03-27 15:45:01 -05:00
if ( $output == OBJECT ) {
2005-06-26 15:55:12 -04:00
return $_post ;
2005-03-27 15:45:01 -05:00
} elseif ( $output == ARRAY_A ) {
2005-06-26 15:55:12 -04:00
return get_object_vars ( $_post );
2005-03-27 15:45:01 -05:00
} elseif ( $output == ARRAY_N ) {
2005-06-26 15:55:12 -04:00
return array_values ( get_object_vars ( $_post ));
2005-03-27 15:45:01 -05:00
} else {
2005-06-26 15:55:12 -04:00
return $_post ;
2005-03-27 15:45:01 -05:00
}
}
2005-03-27 16:56:10 -05:00
// Retrieves page data given a page ID or page object.
// Handles page caching.
function & get_page ( & $page , $output = OBJECT ) {
global $page_cache , $wpdb ;
if ( empty ( $page ) ) {
if ( isset ( $GLOBALS [ 'page' ]) )
2005-06-26 15:55:12 -04:00
$_page = & $GLOBALS [ 'page' ];
2005-03-27 16:56:10 -05:00
else
2005-06-26 15:55:12 -04:00
$_page = null ;
2005-03-27 16:56:10 -05:00
} elseif ( is_object ( $page ) ) {
if ( ! isset ( $page_cache [ $page -> ID ]))
$page_cache [ $page -> ID ] = & $page ;
2005-06-26 15:55:12 -04:00
$_page = & $page_cache [ $page -> ID ];
2005-03-27 16:56:10 -05:00
} else {
if ( isset ( $GLOBALS [ 'page' ]) && ( $page == $GLOBALS [ 'page' ] -> ID ) )
2005-06-26 15:55:12 -04:00
$_page = & $GLOBALS [ 'page' ];
2005-03-27 16:56:10 -05:00
elseif ( isset ( $page_cache [ $page ]))
2005-06-26 15:55:12 -04:00
$_page = & $page_cache [ $page ];
2005-03-27 16:56:10 -05:00
else {
2005-06-26 16:44:58 -04:00
$query = " SELECT * FROM $wpdb->posts WHERE ID= ' $page ' " ;
2005-03-27 16:56:10 -05:00
$page_cache [ $page ] = & $wpdb -> get_row ( $query );
2005-06-26 15:55:12 -04:00
$_page = & $page_cache [ $page ];
2005-03-27 16:56:10 -05:00
}
}
if ( $output == OBJECT ) {
2005-06-26 15:55:12 -04:00
return $_page ;
2005-03-27 16:56:10 -05:00
} elseif ( $output == ARRAY_A ) {
2005-06-26 15:55:12 -04:00
return get_object_vars ( $_page );
2005-03-27 16:56:10 -05:00
} elseif ( $output == ARRAY_N ) {
2005-06-26 15:55:12 -04:00
return array_values ( get_object_vars ( $_page ));
2005-03-27 16:56:10 -05:00
} else {
2005-06-26 15:55:12 -04:00
return $_page ;
2005-03-27 16:56:10 -05:00
}
}
2005-03-27 15:45:01 -05:00
// Retrieves category data given a category ID or category object.
2005-03-30 18:33:37 -05:00
// Handles category caching.
2005-03-27 15:45:01 -05:00
function & get_category ( & $category , $output = OBJECT ) {
2005-03-30 18:33:37 -05:00
global $cache_categories , $wpdb ;
2005-04-03 00:09:31 -05:00
if ( empty ( $category ) )
return null ;
2005-03-31 00:25:54 -05:00
if ( ! isset ( $cache_categories ))
update_category_cache ();
2005-03-30 18:33:37 -05:00
if ( is_object ( $category )) {
if ( ! isset ( $cache_categories [ $category -> cat_ID ]))
$cache_categories [ $category -> cat_ID ] = & $category ;
2005-06-26 15:55:12 -04:00
$_category = & $cache_categories [ $category -> cat_ID ];
2005-03-30 18:33:37 -05:00
} else {
if ( ! isset ( $cache_categories [ $category ]) ) {
2005-06-26 16:44:58 -04:00
$_category = $wpdb -> get_row ( " SELECT * FROM $wpdb->categories WHERE cat_ID = ' $category ' " );
2005-06-26 15:55:12 -04:00
$cache_categories [ $category -> cat_ID ] = & $_category ;
} else {
$_category = & $cache_categories [ $category ];
}
}
if ( $output == OBJECT ) {
return $_category ;
} elseif ( $output == ARRAY_A ) {
return get_object_vars ( $_category );
} elseif ( $output == ARRAY_N ) {
return array_values ( get_object_vars ( $_category ));
} else {
return $_category ;
}
}
// Retrieves comment data given a comment ID or comment object.
// Handles comment caching.
function & get_comment ( & $comment , $output = OBJECT ) {
global $comment_cache , $wpdb ;
if ( empty ( $comment ) )
return null ;
if ( is_object ( $comment )) {
if ( ! isset ( $comment_cache [ $comment -> comment_ID ]))
$comment_cache [ $comment -> comment_ID ] = & $comment ;
$_comment = & $comment_cache [ $comment -> comment_ID ];
} else {
if ( ! isset ( $comment_cache [ $comment ]) ) {
$_comment = $wpdb -> get_row ( " SELECT * FROM $wpdb->comments WHERE comment_ID = ' $comment ' " );
$comment_cache [ $comment -> comment_ID ] = & $_comment ;
2005-03-30 18:33:37 -05:00
} else {
2005-06-26 15:55:12 -04:00
$_comment = & $comment_cache [ $comment ];
2005-03-30 18:33:37 -05:00
}
}
2005-03-27 15:45:01 -05:00
if ( $output == OBJECT ) {
2005-06-26 15:55:12 -04:00
return $_comment ;
2005-03-27 15:45:01 -05:00
} elseif ( $output == ARRAY_A ) {
2005-06-26 15:55:12 -04:00
return get_object_vars ( $_comment );
2005-03-27 15:45:01 -05:00
} elseif ( $output == ARRAY_N ) {
2005-06-26 15:55:12 -04:00
return array_values ( get_object_vars ( $_comment ));
2005-03-27 15:45:01 -05:00
} else {
2005-06-26 15:55:12 -04:00
return $_comment ;
2005-03-27 15:45:01 -05:00
}
}
function get_catname ( $cat_ID ) {
$category = & get_category ( $cat_ID );
return $category -> cat_name ;
2003-04-21 17:37:11 -04:00
}
function gzip_compression () {
2004-06-10 06:01:45 -04:00
if ( strstr ( $_SERVER [ 'PHP_SELF' ], 'wp-admin' ) ) return false ;
if ( ! get_settings ( 'gzipcompression' ) ) return false ;
2004-06-14 18:42:43 -04:00
if ( extension_loaded ( 'zlib' ) ) {
2004-06-14 19:16:03 -04:00
ob_start ( 'ob_gzhandler' );
2004-06-14 18:42:43 -04:00
}
2003-04-21 17:37:11 -04:00
}
// functions to count the page generation time (from phpBB2)
// ( or just any time between timer_start() and timer_stop() )
2004-06-10 06:01:45 -04:00
function timer_stop ( $display = 0 , $precision = 3 ) { //if called like timer_stop(1), will echo $timetotal
global $timestart , $timeend ;
$mtime = microtime ();
$mtime = explode ( ' ' , $mtime );
$mtime = $mtime [ 1 ] + $mtime [ 0 ];
$timeend = $mtime ;
$timetotal = $timeend - $timestart ;
if ( $display )
echo number_format ( $timetotal , $precision );
return $timetotal ;
2003-06-12 18:45:08 -04:00
}
2003-04-21 17:37:11 -04:00
2004-03-21 02:36:07 -05:00
function weblog_ping ( $server = '' , $path = '' ) {
2004-09-16 13:08:56 -04:00
global $wp_version ;
include_once ( ABSPATH . WPINC . '/class-IXR.php' );
// using a timeout of 3 seconds should be enough to cover slow servers
2004-09-17 04:39:12 -04:00
$client = new IXR_Client ( $server , (( ! strlen ( trim ( $path )) || ( '/' == $path )) ? false : $path ));
2004-09-16 13:08:56 -04:00
$client -> timeout = 3 ;
2004-09-17 10:11:28 -04:00
$client -> useragent .= ' -- WordPress/' . $wp_version ;
2004-09-16 13:08:56 -04:00
// when set to true, this outputs debug messages by itself
$client -> debug = false ;
2005-02-13 20:57:48 -05:00
$home = trailingslashit ( get_option ( 'home' ) );
2005-04-22 17:17:10 -04:00
if ( ! $client -> query ( 'weblogUpdates.extendedPing' , get_settings ( 'blogname' ), $home , get_bloginfo ( 'rss2_url' ) ) ) // then try a normal ping
$client -> query ( 'weblogUpdates.ping' , get_settings ( 'blogname' ), $home );
2004-03-21 02:36:07 -05:00
}
function generic_ping ( $post_id = 0 ) {
$services = get_settings ( 'ping_sites' );
2004-03-25 01:11:28 -05:00
$services = preg_replace ( " |( \ s)+| " , '$1' , $services ); // Kill dupe lines
2004-05-10 04:13:42 -04:00
$services = trim ( $services );
if ( '' != $services ) {
$services = explode ( " \n " , $services );
2004-03-25 18:05:25 -05:00
foreach ( $services as $service ) {
2004-09-17 04:39:12 -04:00
weblog_ping ( $service );
2004-03-25 18:05:25 -05:00
}
2004-03-21 02:36:07 -05:00
}
2004-09-03 16:33:15 -04:00
return $post_id ;
2004-03-21 02:36:07 -05:00
}
2003-12-21 21:46:40 -05:00
// Send a Trackback
2003-04-21 17:37:11 -04:00
function trackback ( $trackback_url , $title , $excerpt , $ID ) {
2005-03-18 10:48:30 -05:00
global $wpdb , $wp_version ;
2005-05-17 23:17:55 -04:00
if ( empty ( $trackback_url ))
return ;
2004-06-17 20:22:09 -04:00
$title = urlencode ( $title );
$excerpt = urlencode ( $excerpt );
$blog_name = urlencode ( get_settings ( 'blogname' ));
2003-12-21 21:46:40 -05:00
$tb_url = $trackback_url ;
$url = urlencode ( get_permalink ( $ID ));
2003-04-21 17:37:11 -04:00
$query_string = " title= $title &url= $url &blog_name= $blog_name &excerpt= $excerpt " ;
2003-12-21 21:46:40 -05:00
$trackback_url = parse_url ( $trackback_url );
2004-07-13 13:52:47 -04:00
$http_request = 'POST ' . $trackback_url [ 'path' ] . ( $trackback_url [ 'query' ] ? '?' . $trackback_url [ 'query' ] : '' ) . " HTTP/1.0 \r \n " ;
2003-12-21 21:46:40 -05:00
$http_request .= 'Host: ' . $trackback_url [ 'host' ] . " \r \n " ;
2004-06-14 18:43:27 -04:00
$http_request .= 'Content-Type: application/x-www-form-urlencoded; charset=' . get_settings ( 'blog_charset' ) . " \r \n " ;
2003-12-21 21:46:40 -05:00
$http_request .= 'Content-Length: ' . strlen ( $query_string ) . " \r \n " ;
2005-03-18 10:48:30 -05:00
$http_request .= " User-Agent: WordPress/ " . $wp_version ;
2005-02-17 04:03:23 -05:00
$http_request .= " \r \n \r \n " ;
2003-12-21 21:46:40 -05:00
$http_request .= $query_string ;
2004-09-06 23:15:48 -04:00
if ( '' == $trackback_url [ 'port' ] )
$trackback_url [ 'port' ] = 80 ;
2004-09-10 06:55:44 -04:00
$fs = @ fsockopen ( $trackback_url [ 'host' ], $trackback_url [ 'port' ], $errno , $errstr , 4 );
2003-12-21 21:46:40 -05:00
@ fputs ( $fs , $http_request );
/*
$debug_file = 'trackback.log' ;
$fp = fopen ( $debug_file , 'a' );
fwrite ( $fp , " \n ***** \n Request: \n \n $http_request\n\nResponse : \n \n " );
while ( !@ feof ( $fs )) {
fwrite ( $fp , @ fgets ( $fs , 4096 ));
}
fwrite ( $fp , " \n \n " );
fclose ( $fp );
2003-04-21 17:37:11 -04:00
*/
2003-12-21 21:46:40 -05:00
@ fclose ( $fs );
2004-05-24 04:22:18 -04:00
$wpdb -> query ( " UPDATE $wpdb->posts SET pinged = CONCAT(pinged, ' \n ', ' $tb_url ') WHERE ID = ' $ID ' " );
$wpdb -> query ( " UPDATE $wpdb->posts SET to_ping = REPLACE(to_ping, ' $tb_url ', '') WHERE ID = ' $ID ' " );
2003-04-21 17:37:11 -04:00
return $result ;
}
function make_url_footnote ( $content ) {
preg_match_all ( '/<a(.+?)href=\"(.+?)\"(.*?)>(.+?)<\/a>/' , $content , $matches );
$j = 0 ;
for ( $i = 0 ; $i < count ( $matches [ 0 ]); $i ++ ) {
$links_summary = ( ! $j ) ? " \n " : $links_summary ;
$j ++ ;
$link_match = $matches [ 0 ][ $i ];
$link_number = '[' . ( $i + 1 ) . ']' ;
$link_url = $matches [ 2 ][ $i ];
$link_text = $matches [ 4 ][ $i ];
$content = str_replace ( $link_match , $link_text . ' ' . $link_number , $content );
2004-04-28 03:27:03 -04:00
$link_url = ( strtolower ( substr ( $link_url , 0 , 7 )) != 'http://' ) ? get_settings ( 'home' ) . $link_url : $link_url ;
2003-04-21 17:37:11 -04:00
$links_summary .= " \n " . $link_number . ' ' . $link_url ;
}
$content = strip_tags ( $content );
$content .= $links_summary ;
2003-06-07 13:19:38 -04:00
return $content ;
2003-04-21 17:37:11 -04:00
}
function xmlrpc_getposttitle ( $content ) {
global $post_default_title ;
if ( preg_match ( '/<title>(.+?)<\/title>/is' , $content , $matchtitle )) {
$post_title = $matchtitle [ 0 ];
$post_title = preg_replace ( '/<title>/si' , '' , $post_title );
$post_title = preg_replace ( '/<\/title>/si' , '' , $post_title );
} else {
$post_title = $post_default_title ;
}
2003-06-07 13:19:38 -04:00
return $post_title ;
2003-04-21 17:37:11 -04:00
}
function xmlrpc_getpostcategory ( $content ) {
global $post_default_category ;
if ( preg_match ( '/<category>(.+?)<\/category>/is' , $content , $matchcat )) {
2004-05-22 22:55:10 -04:00
$post_category = trim ( $matchcat [ 1 ], ',' );
$post_category = explode ( ',' , $post_category );
2003-04-21 17:37:11 -04:00
} else {
$post_category = $post_default_category ;
}
2003-06-07 13:19:38 -04:00
return $post_category ;
2003-04-21 17:37:11 -04:00
}
function xmlrpc_removepostdata ( $content ) {
$content = preg_replace ( '/<title>(.+?)<\/title>/si' , '' , $content );
$content = preg_replace ( '/<category>(.+?)<\/category>/si' , '' , $content );
$content = trim ( $content );
2003-06-07 13:19:38 -04:00
return $content ;
2003-04-21 17:37:11 -04:00
}
function debug_fopen ( $filename , $mode ) {
global $debug ;
if ( $debug == 1 ) {
$fp = fopen ( $filename , $mode );
return $fp ;
} else {
return false ;
}
}
function debug_fwrite ( $fp , $string ) {
global $debug ;
if ( $debug == 1 ) {
fwrite ( $fp , $string );
}
}
function debug_fclose ( $fp ) {
global $debug ;
if ( $debug == 1 ) {
fclose ( $fp );
}
}
2005-09-02 12:56:28 -04:00
function check_for_pings () {
global $wpdb ;
$doping = false ;
if ( $wpdb -> get_var ( " SELECT ID FROM $wpdb->posts WHERE TRIM(to_ping) != '' LIMIT 1 " )) {
$doping = true ;
}
if ( $wpdb -> get_var ( " SELECT post_id FROM $wpdb->postmeta WHERE meta_key = '_pingme' OR meta_key = '_encloseme' LIMIT 1 " )) {
$doping = true ;
}
if ( $doping )
echo '<iframe src="' . get_settings ( 'siteurl' ) . '/wp-admin/execute-pings.php?time=' . time () . '" style="border:none;width:1px;height:1px;"></iframe>' ;
}
2004-10-18 08:09:20 -04:00
function do_enclose ( $content , $post_ID ) {
global $wp_version , $wpdb ;
include_once ( ABSPATH . WPINC . '/class-IXR.php' );
2005-02-12 03:58:10 -05:00
$log = debug_fopen ( ABSPATH . '/enclosures.log' , 'a' );
2004-10-18 08:09:20 -04:00
$post_links = array ();
debug_fwrite ( $log , 'BEGIN ' . date ( 'YmdHis' , time ()) . " \n " );
2005-02-12 03:58:10 -05:00
$pung = get_enclosed ( $post_ID );
2004-10-18 08:09:20 -04:00
$ltrs = '\w' ;
$gunk = '/#~:.?+=&%@!\-' ;
$punc = '.:?\-' ;
$any = $ltrs . $gunk . $punc ;
preg_match_all ( " { \ b http : [ $any ] +? (?= [ $punc ] * [^ $any ] | $ )}x " , $content , $post_links_temp );
debug_fwrite ( $log , 'Post contents:' );
debug_fwrite ( $log , $content . " \n " );
foreach ( $post_links_temp [ 0 ] as $link_test ) :
if ( ! in_array ( $link_test , $pung ) ) : // If we haven't pung it already
$test = parse_url ( $link_test );
if ( isset ( $test [ 'query' ]))
$post_links [] = $link_test ;
elseif (( $test [ 'path' ] != '/' ) && ( $test [ 'path' ] != '' ))
$post_links [] = $link_test ;
endif ;
endforeach ;
2005-03-07 03:56:47 -05:00
foreach ( $post_links as $url ) :
2005-04-20 17:07:19 -04:00
if ( $url != '' && ! $wpdb -> get_var ( " SELECT post_id FROM $wpdb->postmeta WHERE post_id = ' $post_ID ' AND meta_key = 'enclosure' AND meta_value LIKE (' $url %') " ) ) {
2005-03-07 03:56:47 -05:00
if ( $headers = wp_get_http_headers ( $url ) ) {
2005-04-20 17:07:19 -04:00
$len = ( int ) $headers [ 'content-length' ];
2005-07-05 16:47:22 -04:00
$type = $wpdb -> escape ( $headers [ 'content-type' ] );
2005-03-07 03:56:47 -05:00
$allowed_types = array ( 'video' , 'audio' );
if ( in_array ( substr ( $type , 0 , strpos ( $type , " / " ) ), $allowed_types ) ) {
$meta_value = " $url\n $len\n $type\n " ;
2005-04-20 17:07:19 -04:00
$wpdb -> query ( " INSERT INTO ` $wpdb->postmeta ` ( `post_id` , `meta_key` , `meta_value` )
VALUES ( '$post_ID' , 'enclosure' , '$meta_value' ) " );
2005-03-07 03:56:47 -05:00
}
}
}
endforeach ;
}
function wp_get_http_headers ( $url ) {
2005-08-18 17:21:24 -04:00
@ set_time_limit ( 60 );
2005-03-07 03:56:47 -05:00
$parts = parse_url ( $url );
2005-05-17 23:17:55 -04:00
$file = $parts [ 'path' ] . ( $parts [ 'query' ] ? '?' . $parts [ 'query' ] : '' );
2005-03-07 03:56:47 -05:00
$host = $parts [ 'host' ];
if ( ! isset ( $parts [ 'port' ] ) )
$parts [ 'port' ] = 80 ;
$head = " HEAD $file HTTP/1.1 \r \n HOST: $host\r\n\r\n " ;
$fp = @ fsockopen ( $host , $parts [ 'port' ], $err_num , $err_msg , 3 );
if ( ! $fp )
return false ;
$response = '' ;
fputs ( $fp , $head );
while ( ! feof ( $fp ) && strpos ( $response , " \r \n \r \n " ) == false )
$response .= fgets ( $fp , 2048 );
fclose ( $fp );
preg_match_all ( '/(.*?): (.*)\r/' , $response , $matches );
$count = count ( $matches [ 1 ]);
for ( $i = 0 ; $i < $count ; $i ++ ) {
$key = strtolower ( $matches [ 1 ][ $i ]);
$headers [ " $key " ] = $matches [ 2 ][ $i ];
}
preg_match ( '/.*([0-9]{3}).*/' , $response , $return );
$headers [ 'response' ] = $return [ 1 ]; // HTTP response code eg 204, 200, 404
return $headers ;
2004-10-18 08:09:20 -04:00
}
2005-01-18 21:21:36 -05:00
// Deprecated. Use the new post loop.
function start_wp () {
global $wp_query , $post ;
2004-08-08 11:31:50 -04:00
2005-01-18 21:21:36 -05:00
// Since the old style loop is being used, advance the query iterator here.
$wp_query -> next_post ();
setup_postdata ( $post );
}
// Setup global post data.
function setup_postdata ( $post ) {
2005-04-09 13:12:36 -04:00
global $id , $postdata , $authordata , $day , $page , $pages , $multipage , $more , $numpages , $wp_query ;
2005-01-18 21:21:36 -05:00
global $pagenow ;
2004-08-08 11:31:50 -04:00
2005-04-09 13:12:36 -04:00
$id = $post -> ID ;
2003-10-27 02:00:42 -05:00
$authordata = get_userdata ( $post -> post_author );
2004-04-26 23:59:13 -04:00
2004-03-24 21:21:40 -05:00
$day = mysql2date ( 'd.m.y' , $post -> post_date );
$currentmonth = mysql2date ( 'm' , $post -> post_date );
2003-10-27 02:00:42 -05:00
$numpages = 1 ;
2005-04-14 00:24:22 -04:00
$page = get_query_var ( 'page' );
2003-10-27 02:00:42 -05:00
if ( ! $page )
$page = 1 ;
2005-04-14 00:24:22 -04:00
if ( is_single () || is_page ())
2003-10-27 02:00:42 -05:00
$more = 1 ;
$content = $post -> post_content ;
2005-01-18 21:21:36 -05:00
if ( preg_match ( '/<!--nextpage-->/' , $content )) {
2003-10-27 02:00:42 -05:00
if ( $page > 1 )
$more = 1 ;
$multipage = 1 ;
$content = str_replace ( " \n <!--nextpage--> \n " , '<!--nextpage-->' , $content );
$content = str_replace ( " \n <!--nextpage--> " , '<!--nextpage-->' , $content );
$content = str_replace ( " <!--nextpage--> \n " , '<!--nextpage-->' , $content );
$pages = explode ( '<!--nextpage-->' , $content );
$numpages = count ( $pages );
} else {
2004-06-11 12:51:39 -04:00
$pages [ 0 ] = $post -> post_content ;
2003-10-27 02:00:42 -05:00
$multipage = 0 ;
}
return true ;
}
function is_new_day () {
global $day , $previousday ;
if ( $day != $previousday ) {
return ( 1 );
} else {
return ( 0 );
}
}
2004-02-16 22:00:20 -05:00
// Filters: these are the core of WP's plugin architecture
2005-02-01 01:20:54 -05:00
function merge_filters ( $tag ) {
2003-12-18 04:36:13 -05:00
global $wp_filter ;
if ( isset ( $wp_filter [ 'all' ])) {
2004-02-09 06:58:49 -05:00
foreach ( $wp_filter [ 'all' ] as $priority => $functions ) {
if ( isset ( $wp_filter [ $tag ][ $priority ]))
$wp_filter [ $tag ][ $priority ] = array_merge ( $wp_filter [ 'all' ][ $priority ], $wp_filter [ $tag ][ $priority ]);
else
$wp_filter [ $tag ][ $priority ] = array_merge ( $wp_filter [ 'all' ][ $priority ], array ());
$wp_filter [ $tag ][ $priority ] = array_unique ( $wp_filter [ $tag ][ $priority ]);
}
2003-10-27 02:00:42 -05:00
}
2004-09-26 20:45:53 -04:00
2005-03-07 10:20:56 -05:00
if ( isset ( $wp_filter [ $tag ]) )
ksort ( $wp_filter [ $tag ] );
2005-02-01 01:20:54 -05:00
}
function apply_filters ( $tag , $string ) {
global $wp_filter ;
2005-03-02 10:28:32 -05:00
$args = array_slice ( func_get_args (), 2 );
2005-02-06 01:13:26 -05:00
2005-02-01 01:20:54 -05:00
merge_filters ( $tag );
2005-03-02 10:28:32 -05:00
if ( ! isset ( $wp_filter [ $tag ])) {
return $string ;
}
foreach ( $wp_filter [ $tag ] as $priority => $functions ) {
if ( ! is_null ( $functions )) {
foreach ( $functions as $function ) {
$all_args = array_merge ( array ( $string ), $args );
$function_name = $function [ 'function' ];
$accepted_args = $function [ 'accepted_args' ];
if ( $accepted_args == 1 ) {
2005-03-10 19:57:34 -05:00
$the_args = array ( $string );
2005-03-02 10:28:32 -05:00
} elseif ( $accepted_args > 1 ) {
2005-03-10 19:57:34 -05:00
$the_args = array_slice ( $all_args , 0 , $accepted_args );
2005-03-02 10:28:32 -05:00
} elseif ( $accepted_args == 0 ) {
2005-03-10 19:57:34 -05:00
$the_args = NULL ;
2005-03-02 10:28:32 -05:00
} else {
2005-03-10 19:57:34 -05:00
$the_args = $all_args ;
2004-09-26 20:45:53 -04:00
}
2005-03-02 10:28:32 -05:00
2005-03-10 19:57:34 -05:00
$string = call_user_func_array ( $function_name , $the_args );
2004-09-26 20:45:53 -04:00
}
2003-10-27 02:00:42 -05:00
}
}
return $string ;
}
2005-03-02 10:28:32 -05:00
function add_filter ( $tag , $function_to_add , $priority = 10 , $accepted_args = 1 ) {
2003-12-18 04:36:13 -05:00
global $wp_filter ;
2005-03-02 10:28:32 -05:00
// check that we don't already have the same filter at the same priority
if ( isset ( $wp_filter [ $tag ][ " $priority " ])) {
foreach ( $wp_filter [ $tag ][ " $priority " ] as $filter ) {
// uncomment if we want to match function AND accepted_args
//if ($filter == array($function, $accepted_args)) {
if ( $filter [ 'function' ] == $function_to_add ) {
return true ;
}
}
2004-02-09 06:58:49 -05:00
}
2005-03-02 10:28:32 -05:00
// So the format is wp_filter['tag']['array of priorities']['array of ['array (functions, accepted_args)]']
$wp_filter [ $tag ][ " $priority " ][] = array ( 'function' => $function_to_add , 'accepted_args' => $accepted_args );
2004-02-09 06:58:49 -05:00
return true ;
}
2005-03-02 10:28:32 -05:00
function remove_filter ( $tag , $function_to_remove , $priority = 10 , $accepted_args = 1 ) {
2004-02-09 06:58:49 -05:00
global $wp_filter ;
2005-03-02 10:28:32 -05:00
// rebuild the list of filters
if ( isset ( $wp_filter [ $tag ][ " $priority " ])) {
foreach ( $wp_filter [ $tag ][ " $priority " ] as $filter ) {
if ( $filter [ 'function' ] != $function_to_remove ) {
$new_function_list [] = $filter ;
2003-10-27 02:00:42 -05:00
}
}
2004-02-09 06:58:49 -05:00
$wp_filter [ $tag ][ " $priority " ] = $new_function_list ;
2003-10-27 02:00:42 -05:00
}
return true ;
}
2004-02-16 22:00:20 -05:00
// The *_action functions are just aliases for the *_filter functions, they take special strings instead of generic content
2005-02-01 01:20:54 -05:00
function do_action ( $tag , $arg = '' ) {
global $wp_filter ;
2005-03-02 10:28:32 -05:00
$extra_args = array_slice ( func_get_args (), 2 );
2005-03-10 19:57:34 -05:00
if ( is_array ( $arg ) )
$args = array_merge ( $arg , $extra_args );
2005-02-01 01:20:54 -05:00
else
2005-03-02 10:28:32 -05:00
$args = array_merge ( array ( $arg ), $extra_args );
2005-02-01 01:20:54 -05:00
merge_filters ( $tag );
2005-03-02 10:28:32 -05:00
if ( ! isset ( $wp_filter [ $tag ])) {
return ;
}
foreach ( $wp_filter [ $tag ] as $priority => $functions ) {
if ( ! is_null ( $functions )) {
foreach ( $functions as $function ) {
$function_name = $function [ 'function' ];
$accepted_args = $function [ 'accepted_args' ];
if ( $accepted_args == 1 ) {
2005-03-10 19:57:34 -05:00
if ( is_array ( $arg ) )
$the_args = $arg ;
else
$the_args = array ( $arg );
2005-03-02 10:28:32 -05:00
} elseif ( $accepted_args > 1 ) {
2005-03-10 19:57:34 -05:00
$the_args = array_slice ( $args , 0 , $accepted_args );
2005-03-02 10:28:32 -05:00
} elseif ( $accepted_args == 0 ) {
2005-03-10 19:57:34 -05:00
$the_args = NULL ;
2005-03-02 10:28:32 -05:00
} else {
2005-03-10 19:57:34 -05:00
$the_args = $args ;
2005-02-01 01:20:54 -05:00
}
2005-03-02 10:28:32 -05:00
2005-03-10 19:57:34 -05:00
$string = call_user_func_array ( $function_name , $the_args );
2005-02-01 01:20:54 -05:00
}
}
}
2004-02-16 22:00:20 -05:00
}
2005-03-02 10:28:32 -05:00
function add_action ( $tag , $function_to_add , $priority = 10 , $accepted_args = 1 ) {
add_filter ( $tag , $function_to_add , $priority , $accepted_args );
2004-02-16 22:00:20 -05:00
}
2005-03-02 10:28:32 -05:00
function remove_action ( $tag , $function_to_remove , $priority = 10 , $accepted_args = 1 ) {
remove_filter ( $tag , $function_to_remove , $priority , $accepted_args );
2004-02-16 22:00:20 -05:00
}
2005-02-16 10:12:04 -05:00
function get_page_uri ( $page_id ) {
2005-03-27 16:56:10 -05:00
$page = get_page ( $page_id );
2004-11-01 20:56:29 -05:00
$uri = urldecode ( $page -> post_name );
2004-10-05 22:18:37 -04:00
2004-11-23 19:12:46 -05:00
// A page cannot be it's own parent.
if ( $page -> post_parent == $page -> ID ) {
return $uri ;
}
2005-03-27 15:45:01 -05:00
2004-10-05 22:18:37 -04:00
while ( $page -> post_parent != 0 ) {
2005-03-27 16:56:10 -05:00
$page = get_page ( $page -> post_parent );
2004-11-01 20:56:29 -05:00
$uri = urldecode ( $page -> post_name ) . " / " . $uri ;
2004-10-05 22:18:37 -04:00
}
return $uri ;
}
2004-02-21 09:10:07 -05:00
function get_posts ( $args ) {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-02-21 09:10:07 -05:00
parse_str ( $args , $r );
if ( ! isset ( $r [ 'numberposts' ])) $r [ 'numberposts' ] = 5 ;
if ( ! isset ( $r [ 'offset' ])) $r [ 'offset' ] = 0 ;
if ( ! isset ( $r [ 'category' ])) $r [ 'category' ] = '' ;
2005-04-09 13:30:57 -04:00
if ( ! isset ( $r [ 'orderby' ])) $r [ 'orderby' ] = 'post_date' ;
if ( ! isset ( $r [ 'order' ])) $r [ 'order' ] = 'DESC' ;
2004-02-21 09:10:07 -05:00
2004-03-24 21:21:40 -05:00
$now = current_time ( 'mysql' );
2004-02-21 09:10:07 -05:00
2005-02-13 19:58:51 -05:00
$posts = $wpdb -> get_results (
" SELECT DISTINCT * FROM $wpdb->posts " .
( empty ( $r [ 'category' ] ) ? " " : " , $wpdb->post2cat " ) .
" WHERE post_date <= ' $now ' AND (post_status = 'publish') " .
( empty ( $r [ 'category' ] ) ? " " : " AND $wpdb->posts .ID = $wpdb->post2cat .post_id AND $wpdb->post2cat .category_id = " . $r [ 'category' ] . " " ) .
2005-04-09 13:30:57 -04:00
" GROUP BY $wpdb->posts .ID ORDER BY " . $r [ 'orderby' ] . " " . $r [ 'order' ] . " LIMIT " . $r [ 'offset' ] . ',' . $r [ 'numberposts' ] );
2004-06-14 23:30:00 -04:00
update_post_caches ( $posts );
2004-02-21 09:10:07 -05:00
return $posts ;
}
2005-03-27 15:45:01 -05:00
function & query_posts ( $query ) {
2005-03-01 04:10:12 -05:00
global $wp_query ;
return $wp_query -> query ( $query );
2004-05-23 22:55:39 -04:00
}
2005-03-27 15:45:01 -05:00
function update_post_cache ( & $posts ) {
global $post_cache ;
2005-03-01 04:10:12 -05:00
if ( ! $posts )
return ;
2005-03-27 15:45:01 -05:00
for ( $i = 0 ; $i < count ( $posts ); $i ++ ) {
$post_cache [ $posts [ $i ] -> ID ] = & $posts [ $i ];
}
}
2005-09-13 20:34:04 -04:00
function clean_post_cache ( $id ) {
global $post_cache ;
if ( isset ( $post_cache [ $id ] ) )
unset ( $post_cache [ $id ] );
}
2005-03-27 16:56:10 -05:00
function update_page_cache ( & $pages ) {
global $page_cache ;
if ( ! $pages )
return ;
for ( $i = 0 ; $i < count ( $pages ); $i ++ ) {
$page_cache [ $pages [ $i ] -> ID ] = & $pages [ $i ];
}
}
2005-09-13 20:34:04 -04:00
function clean_page_cache ( $id ) {
global $page_cache ;
if ( isset ( $page_cache [ $id ] ) )
unset ( $page_cache [ $id ] );
}
2005-03-27 15:45:01 -05:00
function update_post_category_cache ( $post_ids ) {
global $wpdb , $category_cache , $cache_categories ;
if ( empty ( $post_ids ))
return ;
if ( is_array ( $post_ids ))
$post_ids = implode ( ',' , $post_ids );
2005-03-01 04:10:12 -05:00
$dogs = $wpdb -> get_results ( " SELECT DISTINCT
2005-04-19 13:17:36 -04:00
post_id , cat_ID FROM $wpdb -> categories , $wpdb -> post2cat
2005-03-27 15:45:01 -05:00
WHERE category_id = cat_ID AND post_id IN ( $post_ids ) " );
2005-03-31 00:25:54 -05:00
if ( ! isset ( $cache_categories ))
update_category_cache ();
2005-03-01 04:10:12 -05:00
if ( ! empty ( $dogs ) ) {
foreach ( $dogs as $catt ) {
2005-04-19 13:17:36 -04:00
$category_cache [ $catt -> post_id ][ $catt -> cat_ID ] = & $cache_categories [ $catt -> cat_ID ];
2005-03-01 04:10:12 -05:00
}
}
2005-03-27 15:45:01 -05:00
}
function update_post_caches ( & $posts ) {
global $post_cache , $category_cache , $comment_count_cache , $post_meta_cache ;
global $wpdb ;
// No point in doing all this work if we didn't match any posts.
if ( ! $posts )
return ;
// Get the categories for all the posts
for ( $i = 0 ; $i < count ( $posts ); $i ++ ) {
$post_id_list [] = $posts [ $i ] -> ID ;
$post_cache [ $posts [ $i ] -> ID ] = & $posts [ $i ];
}
$post_id_list = implode ( ',' , $post_id_list );
update_post_category_cache ( $post_id_list );
2005-03-01 04:10:12 -05:00
// Do the same for comment numbers
$comment_counts = $wpdb -> get_results ( " SELECT ID, COUNT( comment_ID ) AS ccount
FROM $wpdb -> posts
LEFT JOIN $wpdb -> comments ON ( comment_post_ID = ID AND comment_approved = '1' )
2005-04-09 13:12:36 -04:00
WHERE ID IN ( $post_id_list )
2005-03-01 04:10:12 -05:00
GROUP BY ID " );
if ( $comment_counts ) {
foreach ( $comment_counts as $comment_count )
$comment_count_cache [ " $comment_count->ID " ] = $comment_count -> ccount ;
}
2004-05-23 22:55:39 -04:00
// Get post-meta info
2005-03-01 04:10:12 -05:00
if ( $meta_list = $wpdb -> get_results ( " SELECT post_id, meta_key, meta_value FROM $wpdb->postmeta WHERE post_id IN( $post_id_list ) ORDER BY post_id, meta_key " , ARRAY_A ) ) {
// Change from flat structure to hierarchical:
$post_meta_cache = array ();
foreach ( $meta_list as $metarow ) {
$mpid = $metarow [ 'post_id' ];
$mkey = $metarow [ 'meta_key' ];
$mval = $metarow [ 'meta_value' ];
// Force subkeys to be array type:
if ( ! isset ( $post_meta_cache [ $mpid ]) || ! is_array ( $post_meta_cache [ $mpid ]))
$post_meta_cache [ $mpid ] = array ();
if ( ! isset ( $post_meta_cache [ $mpid ][ " $mkey " ]) || ! is_array ( $post_meta_cache [ $mpid ][ " $mkey " ]))
$post_meta_cache [ $mpid ][ " $mkey " ] = array ();
// Add a value to the current pid/key:
$post_meta_cache [ $mpid ][ $mkey ][] = $mval ;
}
}
2004-05-23 22:55:39 -04:00
}
function update_category_cache () {
2005-03-01 04:10:12 -05:00
global $cache_categories , $wpdb ;
2005-07-11 18:39:50 -04:00
if ( $dogs = $wpdb -> get_results ( " SELECT * FROM $wpdb->categories " )) :
2005-07-12 11:53:13 -04:00
foreach ( $dogs as $catt )
$cache_categories [ $catt -> cat_ID ] = $catt ;
2004-06-10 04:42:25 -04:00
return true ;
2005-07-12 11:53:13 -04:00
else :
2004-06-10 04:42:25 -04:00
return false ;
endif ;
2004-05-23 22:55:39 -04:00
}
2005-09-13 20:03:02 -04:00
function clean_user_cache ( $id ) {
2005-09-13 20:34:04 -04:00
global $cache_userdata ;
2005-09-13 20:03:02 -04:00
if ( isset ( $cache_userdata [ $id ] ) )
unset ( $cache_userdata [ $id ] );
}
2004-04-15 22:24:37 -04:00
function wp_head () {
2005-02-01 01:20:54 -05:00
do_action ( 'wp_head' );
2004-04-15 22:24:37 -04:00
}
2005-03-29 10:11:36 -05:00
function wp_footer () {
do_action ( 'wp_footer' );
}
2004-10-02 15:24:40 -04:00
function is_single ( $post = '' ) {
global $wp_query ;
2004-12-30 05:58:06 -05:00
if ( ! $wp_query -> is_single )
2004-10-02 15:24:40 -04:00
return false ;
2004-12-30 05:58:06 -05:00
if ( empty ( $post ) )
2004-10-02 15:24:40 -04:00
return true ;
2004-06-30 11:31:49 -04:00
2004-10-02 15:24:40 -04:00
$post_obj = $wp_query -> get_queried_object ();
2004-12-30 05:58:06 -05:00
if ( $post == $post_obj -> ID )
2004-10-02 15:24:40 -04:00
return true ;
2004-12-30 05:58:06 -05:00
elseif ( $post == $post_obj -> post_title )
2004-10-02 15:24:40 -04:00
return true ;
2004-12-30 05:58:06 -05:00
elseif ( $post == $post_obj -> post_name )
2004-10-02 15:24:40 -04:00
return true ;
return false ;
2004-06-30 11:31:49 -04:00
}
2004-10-02 15:24:40 -04:00
function is_page ( $page = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_page ) {
return false ;
}
if ( empty ( $page )) {
return true ;
}
2004-08-24 04:43:01 -04:00
2004-10-02 15:24:40 -04:00
$page_obj = $wp_query -> get_queried_object ();
if ( $page == $page_obj -> ID ) {
return true ;
} else if ( $page == $page_obj -> post_title ) {
return true ;
} else if ( $page == $page_obj -> post_name ) {
return true ;
}
return false ;
2004-08-24 04:43:01 -04:00
}
2004-06-30 11:31:49 -04:00
function is_archive () {
2004-08-08 11:31:50 -04:00
global $wp_query ;
2004-06-30 11:31:49 -04:00
2004-08-08 11:31:50 -04:00
return $wp_query -> is_archive ;
2004-06-30 11:31:49 -04:00
}
function is_date () {
2004-08-08 11:31:50 -04:00
global $wp_query ;
2004-06-30 11:31:49 -04:00
2004-08-08 11:31:50 -04:00
return $wp_query -> is_date ;
2004-06-30 11:31:49 -04:00
}
2004-08-23 21:24:48 -04:00
function is_year () {
global $wp_query ;
return $wp_query -> is_year ;
}
function is_month () {
global $wp_query ;
return $wp_query -> is_month ;
}
function is_day () {
global $wp_query ;
return $wp_query -> is_day ;
}
function is_time () {
global $wp_query ;
return $wp_query -> is_time ;
}
2004-10-02 15:24:40 -04:00
function is_author ( $author = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_author ) {
return false ;
}
if ( empty ( $author )) {
return true ;
}
2004-06-30 11:31:49 -04:00
2004-10-02 15:24:40 -04:00
$author_obj = $wp_query -> get_queried_object ();
if ( $author == $author_obj -> ID ) {
return true ;
2005-06-13 04:32:44 -04:00
} else if ( $author == $author_obj -> nickname ) {
2004-10-02 15:24:40 -04:00
return true ;
} else if ( $author == $author_obj -> user_nicename ) {
return true ;
}
return false ;
2004-06-30 11:31:49 -04:00
}
2004-10-02 15:24:40 -04:00
function is_category ( $category = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_category ) {
return false ;
}
if ( empty ( $category )) {
return true ;
}
2004-06-30 11:31:49 -04:00
2004-10-02 15:24:40 -04:00
$cat_obj = $wp_query -> get_queried_object ();
if ( $category == $cat_obj -> cat_ID ) {
return true ;
} else if ( $category == $cat_obj -> cat_name ) {
return true ;
} else if ( $category == $cat_obj -> category_nicename ) {
return true ;
}
return false ;
2004-06-30 11:31:49 -04:00
}
function is_search () {
2004-08-08 11:31:50 -04:00
global $wp_query ;
2004-06-30 11:31:49 -04:00
2004-08-08 11:31:50 -04:00
return $wp_query -> is_search ;
2004-06-30 11:31:49 -04:00
}
function is_feed () {
2004-08-08 11:31:50 -04:00
global $wp_query ;
2004-06-30 11:31:49 -04:00
2004-08-08 11:31:50 -04:00
return $wp_query -> is_feed ;
2004-06-30 11:31:49 -04:00
}
2004-12-17 19:28:24 -05:00
function is_trackback () {
global $wp_query ;
return $wp_query -> is_trackback ;
}
2005-03-27 21:34:16 -05:00
function is_admin () {
global $wp_query ;
return $wp_query -> is_admin ;
}
2004-06-30 11:31:49 -04:00
function is_home () {
2004-08-08 11:31:50 -04:00
global $wp_query ;
return $wp_query -> is_home ;
}
2004-08-27 16:59:38 -04:00
function is_404 () {
global $wp_query ;
return $wp_query -> is_404 ;
}
2005-02-14 04:17:23 -05:00
function is_comments_popup () {
global $wp_query ;
return $wp_query -> is_comments_popup ;
}
2004-11-20 13:32:31 -05:00
function is_paged () {
global $wp_query ;
return $wp_query -> is_paged ;
}
2005-07-17 12:58:13 -04:00
function in_the_loop () {
global $wp_query ;
return $wp_query -> in_the_loop ;
}
2004-08-08 12:47:22 -04:00
function get_query_var ( $var ) {
global $wp_query ;
return $wp_query -> get ( $var );
}
2004-08-08 11:31:50 -04:00
function have_posts () {
global $wp_query ;
return $wp_query -> have_posts ();
}
2004-06-30 11:31:49 -04:00
2004-12-31 16:49:48 -05:00
function rewind_posts () {
global $wp_query ;
return $wp_query -> rewind_posts ();
}
2004-08-08 11:31:50 -04:00
function the_post () {
2005-01-18 21:21:36 -05:00
global $wp_query ;
$wp_query -> the_post ();
2004-06-30 11:31:49 -04:00
}
2005-02-12 14:06:06 -05:00
function get_theme_root () {
return apply_filters ( 'theme_root' , ABSPATH . " wp-content/themes " );
}
function get_theme_root_uri () {
return apply_filters ( 'theme_root_uri' , get_settings ( 'siteurl' ) . " /wp-content/themes " , get_settings ( 'siteurl' ));
}
2004-10-12 23:20:03 -04:00
function get_stylesheet () {
return apply_filters ( 'stylesheet' , get_settings ( 'stylesheet' ));
}
2005-02-12 14:06:06 -05:00
function get_stylesheet_directory () {
$stylesheet = get_stylesheet ();
$stylesheet_dir = get_theme_root () . " / $stylesheet " ;
return apply_filters ( 'stylesheet_directory' , $stylesheet_dir , $stylesheet );
}
function get_stylesheet_directory_uri () {
2005-06-15 14:49:47 -04:00
$stylesheet = rawurlencode ( get_stylesheet () );
2005-02-12 14:06:06 -05:00
$stylesheet_dir_uri = get_theme_root_uri () . " / $stylesheet " ;
return apply_filters ( 'stylesheet_directory_uri' , $stylesheet_dir_uri , $stylesheet );
}
function get_stylesheet_uri () {
$stylesheet_dir_uri = get_stylesheet_directory_uri ();
$stylesheet_uri = $stylesheet_dir_uri . " /style.css " ;
return apply_filters ( 'stylesheet_uri' , $stylesheet_uri , $stylesheet_dir_uri );
}
2004-10-12 23:20:03 -04:00
function get_template () {
return apply_filters ( 'template' , get_settings ( 'template' ));
}
2004-09-30 13:56:16 -04:00
function get_template_directory () {
2004-10-12 23:20:03 -04:00
$template = get_template ();
2005-02-12 14:06:06 -05:00
$template_dir = get_theme_root () . " / $template " ;
return apply_filters ( 'template_directory' , $template_dir , $template );
}
2004-09-30 13:56:16 -04:00
2005-02-12 14:06:06 -05:00
function get_template_directory_uri () {
$template = get_template ();
$template_dir_uri = get_theme_root_uri () . " / $template " ;
return apply_filters ( 'template_directory_uri' , $template_dir_uri , $template );
2004-09-30 13:56:16 -04:00
}
2004-10-13 23:54:57 -04:00
function get_theme_data ( $theme_file ) {
$theme_data = implode ( '' , file ( $theme_file ));
preg_match ( " |Theme Name:(.*)|i " , $theme_data , $theme_name );
preg_match ( " |Theme URI:(.*)|i " , $theme_data , $theme_uri );
preg_match ( " |Description:(.*)|i " , $theme_data , $description );
preg_match ( " |Author:(.*)|i " , $theme_data , $author_name );
preg_match ( " |Author URI:(.*)|i " , $theme_data , $author_uri );
preg_match ( " |Template:(.*)|i " , $theme_data , $template );
if ( preg_match ( " |Version:(.*)|i " , $theme_data , $version ) )
$version = $version [ 1 ];
else
$version = '' ;
2005-03-30 23:44:50 -05:00
if ( preg_match ( " |Status:(.*)|i " , $theme_data , $status ) )
$status = $status [ 1 ];
else
$status = 'publish' ;
2004-10-13 23:54:57 -04:00
$description = wptexturize ( $description [ 1 ]);
$name = $theme_name [ 1 ];
$name = trim ( $name );
$theme = $name ;
if ( '' == $author_uri [ 1 ]) {
$author = $author_name [ 1 ];
} else {
2005-03-10 22:41:04 -05:00
$author = '<a href="' . $author_uri [ 1 ] . '" title="' . __ ( 'Visit author homepage' ) . '">' . $author_name [ 1 ] . '</a>' ;
2004-10-13 23:54:57 -04:00
}
2005-03-30 23:44:50 -05:00
return array ( 'Name' => $name , 'Title' => $theme , 'Description' => $description , 'Author' => $author , 'Version' => $version , 'Template' => $template [ 1 ], 'Status' => $status );
2004-10-13 23:54:57 -04:00
}
function get_themes () {
global $wp_themes ;
2004-10-24 19:48:51 -04:00
global $wp_broken_themes ;
2004-10-13 23:54:57 -04:00
if ( isset ( $wp_themes )) {
return $wp_themes ;
}
$themes = array ();
2004-10-24 19:48:51 -04:00
$wp_broken_themes = array ();
2005-02-12 14:06:06 -05:00
$theme_root = get_theme_root ();
$theme_loc = str_replace ( ABSPATH , '' , $theme_root );
2004-10-13 23:54:57 -04:00
// Files in wp-content/themes directory
$themes_dir = @ dir ( $theme_root );
if ( $themes_dir ) {
while (( $theme_dir = $themes_dir -> read ()) !== false ) {
2005-08-02 20:24:13 -04:00
if ( is_dir ( $theme_root . '/' . $theme_dir ) && is_readable ( $theme_root . '/' . $theme_dir ) ) {
2005-01-31 13:46:17 -05:00
if ( $theme_dir { 0 } == '.' || $theme_dir == '..' || $theme_dir == 'CVS' ) {
2004-10-24 19:48:51 -04:00
continue ;
}
2004-10-13 23:54:57 -04:00
$stylish_dir = @ dir ( $theme_root . '/' . $theme_dir );
2004-10-24 19:48:51 -04:00
$found_stylesheet = false ;
2004-10-13 23:54:57 -04:00
while (( $theme_file = $stylish_dir -> read ()) !== false ) {
if ( $theme_file == 'style.css' ) {
$theme_files [] = $theme_dir . '/' . $theme_file ;
2004-10-24 19:48:51 -04:00
$found_stylesheet = true ;
break ;
2004-10-13 23:54:57 -04:00
}
}
2004-10-24 19:48:51 -04:00
if ( ! $found_stylesheet ) {
$wp_broken_themes [ $theme_dir ] = array ( 'Name' => $theme_dir , 'Title' => $theme_dir , 'Description' => __ ( 'Stylesheet is missing.' ));
}
2004-10-13 23:54:57 -04:00
}
}
}
if ( ! $themes_dir || ! $theme_files ) {
return $themes ;
}
sort ( $theme_files );
foreach ( $theme_files as $theme_file ) {
$theme_data = get_theme_data ( " $theme_root / $theme_file " );
2005-08-07 06:11:30 -04:00
2004-10-13 23:54:57 -04:00
$name = $theme_data [ 'Name' ];
$title = $theme_data [ 'Title' ];
$description = wptexturize ( $theme_data [ 'Description' ]);
$version = $theme_data [ 'Version' ];
$author = $theme_data [ 'Author' ];
$template = $theme_data [ 'Template' ];
$stylesheet = dirname ( $theme_file );
2005-08-23 03:48:23 -04:00
$screenshot = glob ( " $theme_root / $stylesheet /screenshot.* " );
2005-08-07 06:11:30 -04:00
if ( ! empty ( $screenshot ) )
$screenshot = basename ( $screenshot [ 0 ] );
else
$screenshot = false ;
2004-10-24 19:48:51 -04:00
if ( empty ( $name )) {
$name = dirname ( $theme_file );
$title = $name ;
}
2004-10-13 23:54:57 -04:00
if ( empty ( $template )) {
if ( file_exists ( dirname ( " $theme_root / $theme_file /index.php " ))) {
$template = dirname ( $theme_file );
} else {
continue ;
}
}
$template = trim ( $template );
2005-01-01 21:47:45 -05:00
if ( ! file_exists ( " $theme_root / $template /index.php " )) {
2004-10-24 19:48:51 -04:00
$wp_broken_themes [ $name ] = array ( 'Name' => $name , 'Title' => $title , 'Description' => __ ( 'Template is missing.' ));
2004-10-13 23:54:57 -04:00
continue ;
}
$stylesheet_files = array ();
2005-01-01 21:47:45 -05:00
$stylesheet_dir = @ dir ( " $theme_root / $stylesheet " );
if ( $stylesheet_dir ) {
while (( $file = $stylesheet_dir -> read ()) !== false ) {
if ( ! preg_match ( '|^\.+$|' , $file ) && preg_match ( '|\.css$|' , $file ) )
$stylesheet_files [] = " $theme_loc / $stylesheet / $file " ;
2004-10-13 23:54:57 -04:00
}
}
$template_files = array ();
2005-01-01 21:47:45 -05:00
$template_dir = @ dir ( " $theme_root / $template " );
if ( $template_dir ) {
while (( $file = $template_dir -> read ()) !== false ) {
if ( ! preg_match ( '|^\.+$|' , $file ) && preg_match ( '|\.php$|' , $file ) )
$template_files [] = " $theme_loc / $template / $file " ;
2004-10-13 23:54:57 -04:00
}
}
$template_dir = dirname ( $template_files [ 0 ]);
$stylesheet_dir = dirname ( $stylesheet_files [ 0 ]);
if ( empty ( $template_dir )) $template_dir = '/' ;
if ( empty ( $stylesheet_dir )) $stylesheet_dir = '/' ;
2005-04-20 21:35:52 -04:00
// Check for theme name collision. This occurs if a theme is copied to
// a new theme directory and the theme header is not updated. Whichever
// theme is first keeps the name. Subsequent themes get a suffix applied.
// The Default and Classic themes always trump their pretenders.
if ( isset ( $themes [ $name ]) ) {
if ( ( 'WordPress Default' == $name || 'WordPress Classic' == $name ) &&
( 'default' == $stylesheet || 'classic' == $stylesheet ) ) {
// If another theme has claimed to be one of our default themes, move
// them aside.
$suffix = $themes [ $name ][ 'Stylesheet' ];
$new_name = " $name / $suffix " ;
$themes [ $new_name ] = $themes [ $name ];
$themes [ $new_name ][ 'Name' ] = $new_name ;
} else {
$name = " $name / $stylesheet " ;
}
}
2004-10-13 23:54:57 -04:00
2005-08-07 06:11:30 -04:00
$themes [ $name ] = array ( 'Name' => $name , 'Title' => $title , 'Description' => $description , 'Author' => $author , 'Version' => $version , 'Template' => $template , 'Stylesheet' => $stylesheet , 'Template Files' => $template_files , 'Stylesheet Files' => $stylesheet_files , 'Template Dir' => $template_dir , 'Stylesheet Dir' => $stylesheet_dir , 'Status' => $theme_data [ 'Status' ], 'Screenshot' => $screenshot );
2004-10-13 23:54:57 -04:00
}
// Resolve theme dependencies.
$theme_names = array_keys ( $themes );
foreach ( $theme_names as $theme_name ) {
$themes [ $theme_name ][ 'Parent Theme' ] = '' ;
if ( $themes [ $theme_name ][ 'Stylesheet' ] != $themes [ $theme_name ][ 'Template' ]) {
foreach ( $theme_names as $parent_theme_name ) {
if (( $themes [ $parent_theme_name ][ 'Stylesheet' ] == $themes [ $parent_theme_name ][ 'Template' ]) && ( $themes [ $parent_theme_name ][ 'Template' ] == $themes [ $theme_name ][ 'Template' ])) {
$themes [ $theme_name ][ 'Parent Theme' ] = $themes [ $parent_theme_name ][ 'Name' ];
break ;
}
}
}
}
$wp_themes = $themes ;
return $themes ;
}
function get_theme ( $theme ) {
$themes = get_themes ();
if ( array_key_exists ( $theme , $themes )) {
return $themes [ $theme ];
}
return NULL ;
}
function get_current_theme () {
$themes = get_themes ();
$theme_names = array_keys ( $themes );
$current_template = get_settings ( 'template' );
$current_stylesheet = get_settings ( 'stylesheet' );
2005-04-20 21:35:52 -04:00
$current_theme = 'WordPress Default' ;
2004-10-13 23:54:57 -04:00
if ( $themes ) {
foreach ( $theme_names as $theme_name ) {
if ( $themes [ $theme_name ][ 'Stylesheet' ] == $current_stylesheet &&
$themes [ $theme_name ][ 'Template' ] == $current_template ) {
$current_theme = $themes [ $theme_name ][ 'Name' ];
2005-04-20 21:35:52 -04:00
break ;
2004-10-13 23:54:57 -04:00
}
}
}
return $current_theme ;
}
2005-01-31 22:44:32 -05:00
function get_query_template ( $type ) {
$template = '' ;
if ( file_exists ( TEMPLATEPATH . " / { $type } .php " ) )
$template = TEMPLATEPATH . " / { $type } .php " ;
return apply_filters ( " { $type } _template " , $template );
}
function get_404_template () {
return get_query_template ( '404' );
}
function get_archive_template () {
return get_query_template ( 'archive' );
}
function get_author_template () {
return get_query_template ( 'author' );
}
function get_category_template () {
$template = '' ;
if ( file_exists ( TEMPLATEPATH . " /category- " . get_query_var ( 'cat' ) . '.php' ) )
$template = TEMPLATEPATH . " /category- " . get_query_var ( 'cat' ) . '.php' ;
else if ( file_exists ( TEMPLATEPATH . " /category.php " ) )
$template = TEMPLATEPATH . " /category.php " ;
return apply_filters ( 'category_template' , $template );
}
function get_date_template () {
return get_query_template ( 'date' );
}
function get_home_template () {
$template = '' ;
2005-02-05 13:10:05 -05:00
if ( file_exists ( TEMPLATEPATH . " /home.php " ) )
$template = TEMPLATEPATH . " /home.php " ;
else if ( file_exists ( TEMPLATEPATH . " /index.php " ) )
2005-01-31 22:44:32 -05:00
$template = TEMPLATEPATH . " /index.php " ;
return apply_filters ( 'home_template' , $template );
}
2004-10-06 01:11:11 -04:00
function get_page_template () {
global $wp_query ;
$id = $wp_query -> post -> ID ;
$template = get_post_meta ( $id , '_wp_page_template' , true );
2005-01-31 22:44:32 -05:00
if ( 'default' == $template )
$template = '' ;
2004-10-06 01:11:11 -04:00
2005-01-31 22:44:32 -05:00
if ( ! empty ( $template ) && file_exists ( TEMPLATEPATH . " / $template " ) )
$template = TEMPLATEPATH . " / $template " ;
else if ( file_exists ( TEMPLATEPATH . " /page.php " ) )
$template = TEMPLATEPATH . " /page.php " ;
else
$template = '' ;
return apply_filters ( 'page_template' , $template );
}
function get_paged_template () {
return get_query_template ( 'paged' );
}
function get_search_template () {
return get_query_template ( 'search' );
}
2004-10-06 01:11:11 -04:00
2005-01-31 22:44:32 -05:00
function get_single_template () {
return get_query_template ( 'single' );
2004-10-06 01:11:11 -04:00
}
2005-02-14 04:17:23 -05:00
function get_comments_popup_template () {
if ( file_exists ( TEMPLATEPATH . '/comments-popup.php' ) )
$template = TEMPLATEPATH . '/comments-popup.php' ;
else
2005-02-15 14:55:12 -05:00
$template = get_theme_root () . '/default/comments-popup.php' ;
2005-02-14 04:17:23 -05:00
return apply_filters ( 'comments_popup_template' , $template );
}
2004-10-01 20:46:30 -04:00
// Borrowed from the PHP Manual user notes. Convert entities, while
// preserving already-encoded entities:
function htmlentities2 ( $myHTML ) {
$translation_table = get_html_translation_table ( HTML_ENTITIES , ENT_QUOTES );
$translation_table [ chr ( 38 )] = '&' ;
return preg_replace ( " /&(?![A-Za-z] { 0,4} \ w { 2,3};|#[0-9] { 2,3};)/ " , " & " , strtr ( $myHTML , $translation_table ));
}
2005-03-13 11:36:09 -05:00
2004-10-18 23:03:06 -04:00
function is_plugin_page () {
global $plugin_page ;
if ( isset ( $plugin_page )) {
return true ;
}
return false ;
}
2004-10-20 17:28:37 -04:00
/*
add_query_arg : Returns a modified querystring by adding
a single key & value or an associative array .
Setting a key value to emptystring removes the key .
Omitting oldquery_or_uri uses the $_SERVER value .
Parameters :
add_query_arg ( newkey , newvalue , oldquery_or_uri ) or
add_query_arg ( associative_array , oldquery_or_uri )
*/
function add_query_arg () {
$ret = '' ;
if ( is_array ( func_get_arg ( 0 ))) {
$uri = @ func_get_arg ( 1 );
}
else {
2004-11-21 01:03:19 -05:00
if ( @ func_num_args () < 3 ) {
$uri = $_SERVER [ 'REQUEST_URI' ];
} else {
$uri = @ func_get_arg ( 2 );
}
2004-10-20 17:28:37 -04:00
}
2004-11-21 01:03:19 -05:00
2004-10-20 17:28:37 -04:00
if ( strstr ( $uri , '?' )) {
$parts = explode ( '?' , $uri , 2 );
if ( 1 == count ( $parts )) {
$base = '?' ;
$query = $parts [ 0 ];
}
else {
$base = $parts [ 0 ] . '?' ;
$query = $parts [ 1 ];
}
}
2005-02-05 22:42:53 -05:00
else if ( strstr ( $uri , '/' )) {
2004-10-20 17:28:37 -04:00
$base = $uri . '?' ;
$query = '' ;
2005-04-01 00:42:46 -05:00
} else {
$base = '' ;
$query = $uri ;
2004-10-20 17:28:37 -04:00
}
2005-04-01 00:42:46 -05:00
2004-10-20 17:28:37 -04:00
parse_str ( $query , $qs );
if ( is_array ( func_get_arg ( 0 ))) {
$kayvees = func_get_arg ( 0 );
$qs = array_merge ( $qs , $kayvees );
}
else
{
$qs [ func_get_arg ( 0 )] = func_get_arg ( 1 );
}
foreach ( $qs as $k => $v )
{
if ( $v != '' )
{
if ( $ret != '' ) $ret .= '&' ;
$ret .= " $k = $v " ;
}
}
$ret = $base . $ret ;
return trim ( $ret , '?' );
}
function remove_query_arg ( $key , $query ) {
2005-06-19 22:03:35 -04:00
return add_query_arg ( $key , '' , $query );
2004-10-20 17:28:37 -04:00
}
2004-12-03 19:12:08 -05:00
function load_template ( $file ) {
global $posts , $post , $wp_did_header , $wp_did_template_redirect , $wp_query ,
$wp_rewrite , $wpdb ;
extract ( $wp_query -> query_vars );
2004-12-30 16:58:01 -05:00
require_once ( $file );
2004-12-03 19:12:08 -05:00
}
2004-12-15 21:57:05 -05:00
function add_magic_quotes ( $array ) {
2005-07-05 16:47:22 -04:00
global $wpdb ;
2004-12-15 21:57:05 -05:00
foreach ( $array as $k => $v ) {
if ( is_array ( $v )) {
$array [ $k ] = add_magic_quotes ( $v );
} else {
2005-07-05 16:47:22 -04:00
$array [ $k ] = $wpdb -> escape ( $v );
2004-12-15 21:57:05 -05:00
}
}
return $array ;
}
2005-05-03 03:52:11 -04:00
function wp_remote_fopen ( $uri ) {
2005-05-13 17:53:18 -04:00
if ( ini_get ( 'allow_url_fopen' ) ) {
$fp = fopen ( $uri , 'r' );
if ( ! $fp )
return false ;
$linea = '' ;
while ( $remote_read = fread ( $fp , 4096 ) )
$linea .= $remote_read ;
fclose ( $fp );
return $linea ;
} else if ( function_exists ( 'curl_init' ) ) {
2005-05-03 03:52:11 -04:00
$handle = curl_init ();
curl_setopt ( $handle , CURLOPT_URL , $uri );
curl_setopt ( $handle , CURLOPT_CONNECTTIMEOUT , 1 );
curl_setopt ( $handle , CURLOPT_RETURNTRANSFER , 1 );
$buffer = curl_exec ( $handle );
curl_close ( $handle );
return $buffer ;
} else {
2005-05-13 17:53:18 -04:00
return false ;
2005-05-03 03:52:11 -04:00
}
}
2005-06-10 19:15:13 -04:00
function wp ( $query_vars = '' ) {
global $wp ;
$wp -> main ( $query_vars );
}
2005-06-08 20:17:43 -04:00
function status_header ( $header ) {
if ( 200 == $header ) {
$text = 'OK' ;
} elseif ( 301 == $header ) {
$text = 'Moved Permanently' ;
} elseif ( 302 == $header ) {
$text = 'Moved Temporarily' ;
} elseif ( 304 == $header ) {
$text = 'Not Modified' ;
} elseif ( 404 == $header ) {
$text = 'Not Found' ;
} elseif ( 410 == $header ) {
$text = 'Gone' ;
}
if ( preg_match ( '/cgi/' , php_sapi_name ()) ) {
@ header ( " Status: $header $text " );
} else {
if ( version_compare ( phpversion (), '4.3.0' , '>=' ) )
@ header ( $text , TRUE , $header );
else
@ header ( " HTTP/1.x $header $text " );
}
}
function nocache_headers () {
@ header ( 'Expires: Wed, 11 Jan 1984 05:00:00 GMT' );
@ header ( 'Last-Modified: ' . gmdate ( 'D, d M Y H:i:s' ) . ' GMT' );
@ header ( 'Cache-Control: no-cache, must-revalidate, max-age=0' );
@ header ( 'Pragma: no-cache' );
}
2005-07-11 18:39:50 -04:00
function get_usermeta ( $user_id , $meta_key = '' ) {
global $wpdb ;
$user_id = ( int ) $user_id ;
if ( ! empty ( $meta_key ) ) {
$meta_key = preg_replace ( '|a-z0-9_|i' , '' , $meta_key );
2005-07-17 15:55:19 -04:00
$metas = $wpdb -> get_results ( " SELECT meta_key, meta_value FROM $wpdb->usermeta WHERE user_id = ' $user_id ' AND meta_key = ' $meta_key ' " );
2005-07-11 18:39:50 -04:00
} else {
2005-07-17 15:55:19 -04:00
$metas = $wpdb -> get_results ( " SELECT meta_key, meta_value FROM $wpdb->usermeta WHERE user_id = ' $user_id ' " );
2005-07-11 18:39:50 -04:00
}
2005-07-19 10:24:06 -04:00
if ( empty ( $metas ) ) {
if ( empty ( $meta_key ) )
return array ();
else
return '' ;
}
2005-07-11 18:39:50 -04:00
foreach ( $metas as $index => $meta ) {
2005-07-17 15:55:19 -04:00
@ $value = unserialize ( $meta -> meta_value );
if ( $value === FALSE )
$value = $meta -> meta_value ;
$values [] = $value ;
2005-07-11 18:39:50 -04:00
}
2005-07-17 15:55:19 -04:00
if ( count ( $values ) == 1 )
return $values [ 0 ];
2005-07-11 18:39:50 -04:00
else
2005-07-17 15:55:19 -04:00
return $values ;
2005-07-11 18:39:50 -04:00
}
2005-06-12 16:49:13 -04:00
function update_usermeta ( $user_id , $meta_key , $meta_value ) {
global $wpdb ;
2005-07-08 21:27:46 -04:00
if ( ! is_numeric ( $user_id ) )
return false ;
2005-07-23 02:29:46 -04:00
$meta_key = preg_replace ( '|[^a-z0-9_]|i' , '' , $meta_key );
2005-07-11 18:39:50 -04:00
if ( is_array ( $meta_value ) || is_object ( $meta_value ) )
$meta_value = serialize ( $meta_value );
2005-06-12 16:49:13 -04:00
$cur = $wpdb -> get_row ( " SELECT * FROM $wpdb->usermeta WHERE user_id = ' $user_id ' AND meta_key = ' $meta_key ' " );
2005-09-16 13:27:09 -04:00
if ( ! $cur && ! empty ( $meta_value ) ) {
2005-06-12 16:49:13 -04:00
$wpdb -> query ( " INSERT INTO $wpdb->usermeta ( user_id, meta_key, meta_value )
VALUES
( '$user_id' , '$meta_key' , '$meta_value' ) " );
return true ;
}
if ( $cur -> meta_value != $meta_value )
$wpdb -> query ( " UPDATE $wpdb->usermeta SET meta_value = ' $meta_value ' WHERE user_id = ' $user_id ' AND meta_key = ' $meta_key ' " );
2005-09-16 13:27:09 -04:00
if ( empty ( $meta_value ) )
$wpdb -> query ( " DELETE FROM $wpdb->usermeta WHERE user_id = ' $user_id ' AND meta_key = ' $meta_key ' " );
2005-06-12 16:49:13 -04:00
}
2005-07-04 17:53:26 -04:00
function register_activation_hook ( $file , $function ) {
$file = plugin_basename ( $file );
add_action ( 'activate_' . $file , $function );
}
function register_deactivation_hook ( $file , $function ) {
$file = plugin_basename ( $file );
add_action ( 'deactivate_' . $file , $function );
}
function plugin_basename ( $file ) {
return preg_replace ( '/^.*wp-content[\\\\\/]plugins[\\\\\/]/' , '' , $file );
}
2005-07-11 18:39:50 -04:00
?>