2004-01-27 04:33:19 -05:00
< ? php
2004-02-17 03:35:04 -05:00
function url_shorten ( $url ) {
$short_url = str_replace ( 'http://' , '' , stripslashes ( $url ));
$short_url = str_replace ( 'www.' , '' , $short_url );
if ( '/' == substr ( $short_url , - 1 ))
$short_url = substr ( $short_url , 0 , - 1 );
if ( strlen ( $short_url ) > 35 )
$short_url = substr ( $short_url , 0 , 32 ) . '...' ;
return $short_url ;
}
2004-02-13 04:59:47 -05:00
function selected ( $selected , $current ) {
if ( $selected == $current ) echo ' selected="selected"' ;
}
function checked ( $checked , $current ) {
if ( $checked == $current ) echo ' checked="checked"' ;
}
2004-06-16 12:40:40 -04:00
function return_categories_list ( $parent = 0 , $sortbyname = FALSE )
{
/*
* This function returns an list of all categories
* that have $parent as their parent
* if no parent is specified we will assume top level caegories
* are required .
*/
global $wpdb ;
// select sort order
$sort = " cat_id " ;
if ( TRUE == $sortbyname )
{
$sort = " cat_name " ;
}
// First query the database
$cats_tmp = $wpdb -> get_results ( " SELECT cat_id FROM $wpdb->categories WHERE category_parent = $parent ORDER BY $sort " );
// Now strip this down to a simple array of IDs
$cats = array ();
if ( count ( $cats_tmp ) > 0 )
{
foreach ( $cats_tmp as $cat )
{
$cats [] = $cat -> cat_id ;
}
}
// Return the list of categories
return $cats ;
}
function get_nested_categories ( $default = 0 , $parent = 0 ) {
2004-05-24 04:22:18 -04:00
global $post_ID , $mode , $wpdb ;
2004-02-09 03:55:29 -05:00
2004-04-30 04:56:49 -04:00
if ( $post_ID ) {
2004-02-09 03:55:29 -05:00
$checked_categories = $wpdb -> get_col ( "
SELECT category_id
2004-06-16 12:40:40 -04:00
FROM $wpdb -> categories , $wpdb -> post2cat
2004-05-24 04:22:18 -04:00
WHERE $wpdb -> post2cat . category_id = cat_ID AND $wpdb -> post2cat . post_id = '$post_ID'
2004-02-09 03:55:29 -05:00
" );
2004-06-16 12:40:40 -04:00
if ( count ( $checked_categories ) == 0 )
{
// No selected categories, strange
$checked_categories [] = $default ;
}
2004-02-09 03:55:29 -05:00
} else {
$checked_categories [] = $default ;
}
2004-06-16 12:40:40 -04:00
$cats = return_categories_list ( $parent , TRUE );
2004-02-09 03:55:29 -05:00
$result = array ();
2004-06-16 12:40:40 -04:00
foreach ( $cats as $cat )
{
$result [ $cat ][ 'children' ] = get_nested_categories ( $default , $cat );
$result [ $cat ][ 'cat_ID' ] = $cat ;
$result [ $cat ][ 'checked' ] = in_array ( $cat , $checked_categories );
2004-06-17 20:22:09 -04:00
$result [ $cat ][ 'cat_name' ] = get_the_category_by_ID ( $cat );
2004-02-09 03:55:29 -05:00
}
2004-06-16 12:40:40 -04:00
return $result ;
2004-02-09 03:55:29 -05:00
}
function write_nested_categories ( $categories ) {
foreach ( $categories as $category ) {
echo '<label for="category-' , $category [ 'cat_ID' ], '" class="selectit"><input value="' , $category [ 'cat_ID' ],
'" type="checkbox" name="post_category[]" id="category-' , $category [ 'cat_ID' ], '"' ,
2004-06-29 22:02:49 -04:00
( $category [ 'checked' ] ? ' checked="checked"' : " " ), '/> ' , htmlspecialchars ( $category [ 'cat_name' ]), " </label> \n " ;
2004-02-09 03:55:29 -05:00
if ( isset ( $category [ 'children' ])) {
echo " \n <span class='cat-nest'> \n " ;
2004-05-07 17:05:02 -04:00
write_nested_categories ( $category [ 'children' ]);
2004-02-09 03:55:29 -05:00
echo " </span> \n " ;
}
}
}
function dropdown_categories ( $default = 0 ) {
write_nested_categories ( get_nested_categories ( $default ));
}
2004-01-27 04:33:19 -05:00
// Dandy new recursive multiple category stuff.
2004-01-31 21:00:26 -05:00
function cat_rows ( $parent = 0 , $level = 0 , $categories = 0 ) {
2004-05-24 04:22:18 -04:00
global $wpdb , $bgcolor ;
2004-01-31 21:00:26 -05:00
if ( ! $categories ) {
2004-05-24 04:22:18 -04:00
$categories = $wpdb -> get_results ( " SELECT * FROM $wpdb->categories ORDER BY cat_name " );
2004-01-31 21:00:26 -05:00
}
2004-01-27 04:33:19 -05:00
if ( $categories ) {
foreach ( $categories as $category ) {
2004-01-31 21:00:26 -05:00
if ( $category -> category_parent == $parent ) {
2004-06-18 23:57:57 -04:00
$category -> cat_name = htmlspecialchars ( $category -> cat_name );
2004-05-24 04:22:18 -04:00
$count = $wpdb -> get_var ( " SELECT COUNT(post_id) FROM $wpdb->post2cat WHERE category_id = $category->cat_ID " );
2004-01-31 21:00:26 -05:00
$pad = str_repeat ( '— ' , $level );
2004-01-27 04:33:19 -05:00
2004-07-06 14:14:42 -04:00
$class = ( 'alternate' == $class ) ? '' : 'alternate' ;
echo " <tr class=' $class '><th scope='row'> $category->cat_ID </th><td> $pad $category->cat_name </td>
2004-01-31 21:00:26 -05:00
< td > $category -> category_description </ td >
< td > $count </ td >
2004-04-23 02:46:53 -04:00
< td >< a href = 'categories.php?action=edit&cat_ID=$category->cat_ID' class = 'edit' > " . __('Edit') . " </ a ></ td >< td >< a href = 'categories.php?action=Delete&cat_ID=$category->cat_ID' onclick = \ " return confirm(' " . sprintf ( __ ( " You are about to delete the category \ '%s \ '. All of its posts will go to the default category. \\ n \ 'OK \ ' to delete, \ 'Cancel \ ' to stop. " ), addslashes ( $category -> cat_name )) . " ') \" class='delete'> " . __ ( 'Delete' ) . " </a></td>
2004-01-31 21:00:26 -05:00
</ tr > " ;
2004-01-27 04:33:19 -05:00
cat_rows ( $category -> cat_ID , $level + 1 );
2004-01-31 21:00:26 -05:00
}
2004-01-27 04:33:19 -05:00
}
} else {
return false ;
}
}
2004-01-31 21:00:26 -05:00
function wp_dropdown_cats ( $currentcat , $currentparent = 0 , $parent = 0 , $level = 0 , $categories = 0 ) {
2004-05-24 04:22:18 -04:00
global $wpdb , $bgcolor ;
2004-01-31 21:00:26 -05:00
if ( ! $categories ) {
2004-05-24 04:22:18 -04:00
$categories = $wpdb -> get_results ( " SELECT * FROM $wpdb->categories ORDER BY cat_name " );
2004-01-31 21:00:26 -05:00
}
2004-01-27 04:33:19 -05:00
if ( $categories ) {
2004-01-31 21:00:26 -05:00
foreach ( $categories as $category ) { if ( $currentcat != $category -> cat_ID && $parent == $category -> category_parent ) {
2004-05-24 04:22:18 -04:00
$count = $wpdb -> get_var ( " SELECT COUNT(post_id) FROM $wpdb->post2cat WHERE category_id = $category->cat_ID " );
2004-01-27 04:33:19 -05:00
$pad = str_repeat ( '– ' , $level );
2004-06-18 23:57:57 -04:00
$category -> cat_name = htmlspecialchars ( $category -> cat_name );
2004-01-27 04:33:19 -05:00
echo " \n \t <option value=' $category->cat_ID ' " ;
if ( $currentparent == $category -> cat_ID )
echo " selected='selected' " ;
echo " > $pad $category->cat_name </option> " ;
2004-01-31 21:00:26 -05:00
wp_dropdown_cats ( $currentcat , $currentparent , $category -> cat_ID , $level + 1 , $categories );
2004-01-27 04:33:19 -05:00
} }
} else {
return false ;
}
}
2004-02-05 09:28:02 -05:00
function wp_create_thumbnail ( $file , $max_side , $effect = '' ) {
// 1 = GIF, 2 = JPEG, 3 = PNG
if ( file_exists ( $file )) {
$type = getimagesize ( $file );
// if the associated function doesn't exist - then it's not
// handle. duh. i hope.
if ( ! function_exists ( 'imagegif' ) && $type [ 2 ] == 1 ) {
2004-04-23 02:46:53 -04:00
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
2004-02-05 09:28:02 -05:00
} elseif ( ! function_exists ( 'imagejpeg' ) && $type [ 2 ] == 2 ) {
2004-04-23 02:46:53 -04:00
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
2004-02-05 09:28:02 -05:00
} elseif ( ! function_exists ( 'imagepng' ) && $type [ 2 ] == 3 ) {
2004-04-23 02:46:53 -04:00
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
2004-02-05 09:28:02 -05:00
} else {
// create the initial copy from the original file
if ( $type [ 2 ] == 1 ) {
$image = imagecreatefromgif ( $file );
} elseif ( $type [ 2 ] == 2 ) {
$image = imagecreatefromjpeg ( $file );
} elseif ( $type [ 2 ] == 3 ) {
$image = imagecreatefrompng ( $file );
}
if ( function_exists ( 'imageantialias' ))
imageantialias ( $image , TRUE );
$image_attr = getimagesize ( $file );
// figure out the longest side
if ( $image_attr [ 0 ] > $image_attr [ 1 ]) {
$image_width = $image_attr [ 0 ];
$image_height = $image_attr [ 1 ];
$image_new_width = $max_side ;
$image_ratio = $image_width / $image_new_width ;
$image_new_height = $image_height / $image_ratio ;
//width is > height
} else {
$image_width = $image_attr [ 0 ];
$image_height = $image_attr [ 1 ];
$image_new_height = $max_side ;
$image_ratio = $image_height / $image_new_height ;
$image_new_width = $image_width / $image_ratio ;
//height > width
}
$thumbnail = imagecreatetruecolor ( $image_new_width , $image_new_height );
@ imagecopyresized ( $thumbnail , $image , 0 , 0 , 0 , 0 , $image_new_width , $image_new_height , $image_attr [ 0 ], $image_attr [ 1 ]);
// move the thumbnail to it's final destination
$path = explode ( '/' , $file );
$thumbpath = substr ( $file , 0 , strrpos ( $file , '/' )) . '/thumb-' . $path [ count ( $path ) - 1 ];
if ( $type [ 2 ] == 1 ) {
if ( ! imagegif ( $thumbnail , $thumbpath )) {
2004-04-23 02:46:53 -04:00
$error = __ ( " Thumbnail path invalid " );
2004-02-05 09:28:02 -05:00
}
} elseif ( $type [ 2 ] == 2 ) {
if ( ! imagejpeg ( $thumbnail , $thumbpath )) {
2004-04-23 02:46:53 -04:00
$error = __ ( " Thumbnail path invalid " );
2004-02-05 09:28:02 -05:00
}
} elseif ( $type [ 2 ] == 3 ) {
if ( ! imagepng ( $thumbnail , $thumbpath )) {
2004-04-23 02:46:53 -04:00
$error = __ ( " Thumbnail path invalid " );
2004-02-05 09:28:02 -05:00
}
}
}
}
if ( ! empty ( $error ))
{
return $error ;
}
else
{
return 1 ;
}
}
2004-03-23 13:02:05 -05:00
// Some postmeta stuff
function has_meta ( $postid ) {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-03-23 13:02:05 -05:00
return $wpdb -> get_results ( "
SELECT meta_key , meta_value , meta_id , post_id
2004-05-24 04:22:18 -04:00
FROM $wpdb -> postmeta
2004-05-05 04:18:30 -04:00
WHERE post_id = '$postid'
2004-03-23 13:02:05 -05:00
ORDER BY meta_key , meta_id " ,ARRAY_A);
}
function list_meta ( $meta ) {
global $post_ID ;
// Exit if no meta
2004-04-27 22:23:46 -04:00
if ( ! $meta ) return ;
?>
2004-04-28 15:49:27 -04:00
< table id = 'meta-list' cellpadding = " 3 " >
2004-04-27 22:23:46 -04:00
< tr >
< th >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
< th colspan = '2' >< ? php _e ( 'Action' ) ?> </th>
</ tr >
< ? php
2004-03-23 13:02:05 -05:00
foreach ( $meta as $entry ) {
2004-04-27 22:23:46 -04:00
$style = ( 'class="alternate"' == $style ) ? '' : 'class="alternate"' ;
echo "
< tr $style >
2004-04-28 15:49:27 -04:00
< td valign = 'top' >< input name = 'meta[{$entry[' meta_id ']}][key]' tabindex = '6' type = 'text' size = '20' value = '{$entry[' meta_key ']}' /></ td >
< td >< textarea name = 'meta[{$entry[' meta_id ']}][value]' tabindex = '6' rows = '2' cols = '30' > { $entry [ 'meta_value' ]} </ textarea ></ td >
< td align = 'center' width = '10%' >< input name = 'updatemeta' type = 'submit' class = 'updatemeta' tabindex = '6' value = '" . __(' Update ') ."' /></ td >
< td align = 'center' width = '10%' >< input name = 'deletemeta[{$entry[' meta_id ']}]' type = 'submit' class = 'deletemeta' tabindex = '6' value = '" . __(' Delete ') ."' /></ td >
2004-04-27 22:23:46 -04:00
</ tr >
" ;
2004-03-23 13:02:05 -05:00
}
2004-04-27 22:23:46 -04:00
echo "
</ table >
" ;
2004-03-23 13:02:05 -05:00
}
// Get a list of previously defined keys
function get_meta_keys () {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-03-23 13:02:05 -05:00
$keys = $wpdb -> get_col ( "
SELECT meta_key
2004-05-24 04:22:18 -04:00
FROM $wpdb -> postmeta
2004-03-23 13:02:05 -05:00
GROUP BY meta_key
ORDER BY meta_key " );
return $keys ;
}
function meta_form () {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-04-28 00:49:16 -04:00
$keys = $wpdb -> get_col ( "
SELECT meta_key
2004-05-24 04:22:18 -04:00
FROM $wpdb -> postmeta
2004-04-28 00:49:16 -04:00
GROUP BY meta_key
ORDER BY meta_id DESC
LIMIT 10 " );
2004-03-23 13:02:05 -05:00
?>
2004-04-28 00:49:16 -04:00
< h3 >< ? php _e ( 'Add a new custom field to this post:' ) ?> </h3>
2004-04-28 15:49:27 -04:00
< table cellspacing = " 3 " cellpadding = " 3 " >
2004-04-27 22:23:46 -04:00
< tr >
< th colspan = " 2 " >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
</ tr >
< tr valign = " top " >
2004-05-20 07:32:14 -04:00
< td align = " right " width = " 18% " >
< ? php if ( $keys ) : ?>
< select id = " metakeyselect " name = " metakeyselect " tabindex = " 7 " >
2004-03-23 13:02:05 -05:00
< option value = " #NONE# " >- Select -</ option >
< ? php
foreach ( $keys as $key ) {
2004-04-27 22:23:46 -04:00
echo " \n \t <option value=' $key '> $key </option> " ;
2004-03-23 13:02:05 -05:00
}
?>
2004-05-20 07:32:14 -04:00
</ select > or
< ? php endif ; ?>
</ td >
2004-04-28 15:49:27 -04:00
< td >< input type = " text " id = " metakeyinput " name = " metakeyinput " tabindex = " 7 " /></ td >
2004-04-28 01:37:11 -04:00
< td >< textarea id = " metavalue " name = " metavalue " rows = " 3 " cols = " 25 " tabindex = " 7 " ></ textarea ></ td >
2004-04-27 22:23:46 -04:00
</ tr >
2004-03-23 13:02:05 -05:00
2004-04-27 22:23:46 -04:00
</ table >
2004-05-26 11:00:42 -04:00
< p class = " submit " >< input type = " submit " name = " updatemeta " tabindex = " 7 " value = " <?php _e('Add Custom Field »') ?> " /></ p >
2004-03-23 13:02:05 -05:00
< ? php
}
function add_meta ( $post_ID ) {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-03-23 13:02:05 -05:00
2004-04-27 22:23:46 -04:00
$metakeyselect = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metakeyselect' ]) ) );
$metakeyinput = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metakeyinput' ]) ) );
$metavalue = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metavalue' ]) ) );
2004-03-23 13:02:05 -05:00
2004-04-12 13:31:37 -04:00
if ( ! empty ( $metavalue ) && ((( '#NONE#' != $metakeyselect ) && ! empty ( $metakeyselect )) || ! empty ( $metakeyinput ))) {
2004-03-23 13:02:05 -05:00
// We have a key/value pair. If both the select and the
// input for the key have data, the input takes precedence:
if ( '#NONE#' != $metakeyselect )
$metakey = $metakeyselect ;
if ( $metakeyinput )
$metakey = $metakeyinput ; // default
$result = $wpdb -> query ( "
2004-05-24 04:22:18 -04:00
INSERT INTO $wpdb -> postmeta
2004-03-23 13:02:05 -05:00
( post_id , meta_key , meta_value )
VALUES ( '$post_ID' , '$metakey' , '$metavalue' )
" );
}
} // add_meta
2004-04-28 00:49:16 -04:00
function delete_meta ( $mid ) {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-04-27 22:23:46 -04:00
2004-05-24 04:22:18 -04:00
$result = $wpdb -> query ( " DELETE FROM $wpdb->postmeta WHERE meta_id = ' $mid ' " );
2004-03-23 13:02:05 -05:00
}
2004-04-28 00:49:16 -04:00
function update_meta ( $mid , $mkey , $mvalue ) {
2004-05-24 04:22:18 -04:00
global $wpdb ;
2004-04-28 00:49:16 -04:00
2004-05-24 04:22:18 -04:00
return $wpdb -> query ( " UPDATE $wpdb->postmeta SET meta_key = ' $mkey ', meta_value = ' $mvalue ' WHERE meta_id = ' $mid ' " );
2004-04-28 00:49:16 -04:00
}
2004-04-30 04:56:49 -04:00
function touch_time ( $edit = 1 ) {
global $month , $postdata ;
// echo $postdata['Date'];
if ( 'draft' == $postdata -> post_status ) {
$checked = 'checked="checked" ' ;
$edit = false ;
} else {
$checked = ' ' ;
}
2004-08-01 04:28:56 -04:00
echo '<fieldset><legend><input type="checkbox" class="checkbox" name="edit_date" value="1" id="timestamp" ' . $checked . '/> <label for="timestamp">' . __ ( 'Edit timestamp' ) . '</label></legend>' ;
2004-04-30 04:56:49 -04:00
$time_adj = time () + ( get_settings ( 'gmt_offset' ) * 3600 );
$post_date = $postdata -> post_date ;
$jj = ( $edit ) ? mysql2date ( 'd' , $post_date ) : gmdate ( 'd' , $time_adj );
$mm = ( $edit ) ? mysql2date ( 'm' , $post_date ) : gmdate ( 'm' , $time_adj );
$aa = ( $edit ) ? mysql2date ( 'Y' , $post_date ) : gmdate ( 'Y' , $time_adj );
$hh = ( $edit ) ? mysql2date ( 'H' , $post_date ) : gmdate ( 'H' , $time_adj );
$mn = ( $edit ) ? mysql2date ( 'i' , $post_date ) : gmdate ( 'i' , $time_adj );
$ss = ( $edit ) ? mysql2date ( 's' , $post_date ) : gmdate ( 's' , $time_adj );
echo " <select name= \" mm \" > \n " ;
for ( $i = 1 ; $i < 13 ; $i = $i + 1 ) {
echo " \t \t \t <option value= \" $i\ " " ;
if ( $i == $mm )
echo " selected='selected' " ;
if ( $i < 10 ) {
$ii = " 0 " . $i ;
} else {
$ii = " $i " ;
}
echo " > " . $month [ " $ii " ] . " </option> \n " ;
2004-08-01 04:28:56 -04:00
}
?>
2004-04-30 04:56:49 -04:00
</ select >
2004-08-01 04:28:56 -04:00
< input type = " text " name = " jj " value = " <?php echo $jj ; ?> " size = " 2 " maxlength = " 2 " />
2004-04-30 04:56:49 -04:00
< input type = " text " name = " aa " value = " <?php echo $aa ?> " size = " 4 " maxlength = " 5 " /> @
< input type = " text " name = " hh " value = " <?php echo $hh ?> " size = " 2 " maxlength = " 2 " /> :
2004-08-01 04:28:56 -04:00
< input type = " text " name = " mn " value = " <?php echo $mn ?> " size = " 2 " maxlength = " 2 " />
< input type = " hidden " name = " ss " value = " <?php echo $ss ?> " size = " 2 " maxlength = " 2 " /> < ? php _e ( 'Existing timestamp' ); ?> : <?php echo "{$month[$mm]} $jj, $aa @ $hh:$mn"; ?></fieldset>
2004-04-30 04:56:49 -04:00
< ? php
}
2004-05-17 15:40:56 -04:00
function check_admin_referer () {
2004-05-19 02:44:55 -04:00
$adminurl = strtolower ( get_settings ( 'siteurl' )) . '/wp-admin' ;
$referer = strtolower ( $_SERVER [ 'HTTP_REFERER' ]);
if ( ! strstr ( $referer , $adminurl ) ) {
2004-05-17 15:40:56 -04:00
die ( 'Sorry, you need to enable sending referrers, for this feature to work.' );
}
}
2004-07-27 19:37:45 -04:00
// insert_with_markers: Owen Winkler
// Inserts an array of strings into a file (.htaccess), placing it between
// BEGIN and END markers. Replaces existing marked info. Retains surrounding
// data. Creates file if none exists.
// Returns true on write success, false on failure.
function insert_with_markers ( $filename , $marker , $insertion ) {
2004-09-26 22:32:51 -04:00
if ( ! file_exists ( $filename ) || is_writeable ( $filename )) {
if ( ! file_exists ( $filename )) {
$markerdata = '' ;
} else {
$markerdata = explode ( " \n " , implode ( '' , file ( $filename )));
}
$f = fopen ( $filename , 'w' );
$foundit = false ;
if ( $markerdata ) {
$state = true ;
$newline = '' ;
foreach ( $markerdata as $markerline ) {
if ( strstr ( $markerline , " # BEGIN { $marker } " )) $state = false ;
if ( $state ) fwrite ( $f , " { $newline } { $markerline } " );
if ( strstr ( $markerline , " # END { $marker } " )) {
fwrite ( $f , " { $newline } # BEGIN { $marker } " );
if ( is_array ( $insertion )) foreach ( $insertion as $insertline ) fwrite ( $f , " { $newline } { $insertline } " );
fwrite ( $f , " { $newline } # END { $marker } " );
$state = true ;
$foundit = true ;
}
$newline = " \n " ;
}
}
if ( ! $foundit ) {
fwrite ( $f , " # BEGIN { $marker } \n " );
foreach ( $insertion as $insertline ) fwrite ( $f , " { $insertline } \n " );
fwrite ( $f , " # END { $marker } " );
}
fclose ( $f );
return true ;
} else {
return false ;
}
2004-07-27 19:37:45 -04:00
}
// insert_with_markers: Owen Winkler
// Returns an array of strings from a file (.htaccess) from between BEGIN
// and END markers.
function extract_from_markers ( $filename , $marker ) {
2004-09-26 22:32:51 -04:00
$result = array ();
2004-07-27 19:37:45 -04:00
2004-09-26 22:32:51 -04:00
if ( ! file_exists ( $filename )) {
return $result ;
}
if ( $markerdata = explode ( " \n " , implode ( '' , file ( $filename ))));
{
$state = false ;
foreach ( $markerdata as $markerline ) {
if ( strstr ( $markerline , " # END { $marker } " )) $state = false ;
if ( $state ) $result [] = $markerline ;
if ( strstr ( $markerline , " # BEGIN { $marker } " )) $state = true ;
}
}
return $result ;
2004-07-27 19:37:45 -04:00
}
2004-10-05 22:18:37 -04:00
function save_mod_rewrite_rules () {
global $is_apache ;
$home = get_settings ( 'home' );
if ( $home != '' && $home != get_settings ( 'siteurl' ) ) {
$home_path = parse_url ( $home );
$home_path = $home_root [ 'path' ];
$root = str_replace ( $_SERVER [ " PHP_SELF " ], '' , $_SERVER [ " PATH_TRANSLATED " ]);
$home_path = $root . $home_path . " / " ;
} else {
$home_path = ABSPATH ;
}
if ( ( ! file_exists ( $home_path . '.htaccess' ) && is_writable ( $home_path )) || is_writable ( $home_path . '.htaccess' ) )
$writable = true ;
else
$writable = false ;
$permalink_structure = get_settings ( 'permalink_structure' );
if ( strstr ( $permalink_structure , 'index.php' ) ) // If they're using
$usingpi = true ;
else
$usingpi = false ;
if ( $writable && ! $usingpi && $is_apache ) {
$rules = explode ( " \n " , mod_rewrite_rules ( $permalink_structure ));
insert_with_markers ( $home_path . '.htaccess' , 'WordPress' , $rules );
}
}
function generate_page_rewrite_rules () {
global $wpdb ;
$posts = $wpdb -> get_results ( " SELECT ID, post_name FROM $wpdb->posts WHERE post_status = 'static' " );
$page_rewrite_rules = array ();
2004-10-07 20:16:44 -04:00
if ( $posts ) {
foreach ( $posts as $post ) {
// URI => page name
$uri = get_page_uri ( $post -> ID );
$page_rewrite_rules [ $uri ] = $post -> post_name ;
}
update_option ( 'page_uris' , $page_rewrite_rules );
save_mod_rewrite_rules ();
2004-10-05 22:18:37 -04:00
}
}
2004-09-09 13:51:33 -04:00
function the_quicktags () {
// Browser detection sucks, but until Safari supports the JS needed for this to work people just assume it's a bug in WP
if ( ! strstr ( $_SERVER [ 'HTTP_USER_AGENT' ], 'Safari' ) ) :
echo '
< div id = " quicktags " >
< a href = " http://wordpress.org/docs/reference/post/#quicktags " title = " ' . __('Help with quicktags') . ' " > ' . __(' Quicktags ') . ' </ a >:
< script src = " quicktags.js " type = " text/javascript " ></ script >
< script type = " text/javascript " > edToolbar (); </ script >
' ;
echo '</div>' ;
endif ;
}
2004-09-16 14:09:32 -04:00
function validate_current_theme () {
$theme_loc = 'wp-content/themes' ;
$theme_root = ABSPATH . $theme_loc ;
$template = get_settings ( 'template' );
$stylesheet = get_settings ( 'stylesheet' );
if (( $template != 'default' ) && ( ! file_exists ( " $theme_root / $template /index.php " ))) {
update_option ( 'template' , 'default' );
update_option ( 'stylesheet' , 'default' );
2004-10-06 02:20:52 -04:00
do_action ( 'switch_theme' , 'Default' );
2004-09-16 14:09:32 -04:00
return false ;
}
if (( $stylesheet != 'default' ) && ( ! file_exists ( " $theme_root / $stylesheet /style.css " ))) {
update_option ( 'template' , 'default' );
update_option ( 'stylesheet' , 'default' );
2004-10-06 02:20:52 -04:00
do_action ( 'switch_theme' , 'Default' );
2004-09-16 14:09:32 -04:00
return false ;
}
return true ;
}
2004-10-06 01:11:11 -04:00
function get_page_templates () {
$themes = get_themes ();
$theme = get_current_theme ();
$templates = $themes [ $theme ][ 'Template Files' ];
$page_templates = array ();
foreach ( $templates as $template ) {
$template_data = implode ( '' , file ( ABSPATH . $template ));
preg_match ( " |Template Name:(.*)|i " , $template_data , $name );
preg_match ( " |Description:(.*)|i " , $template_data , $description );
$name = $name [ 1 ];
$description = $description [ 1 ];
if ( ! empty ( $name )) {
$page_templates [ trim ( $name )] = basename ( $template );
}
}
return $page_templates ;
}
function page_template_dropdown ( $default = '' ) {
$templates = get_page_templates ();
foreach ( array_keys ( $templates ) as $template ) :
if ( $default == $templates [ $template ]) $selected = " selected='selected' " ;
else $selected = '' ;
echo " \n \t <option value=' " . $templates [ $template ] . " ' $selected > $template </option> " ;
endforeach ;
}
2004-10-05 22:18:37 -04:00
function parent_dropdown ( $default = 0 , $parent = 0 , $level = 0 ) {
2004-10-05 04:27:13 -04:00
global $wpdb ;
$items = $wpdb -> get_results ( " SELECT ID, post_parent, post_title FROM $wpdb->posts WHERE post_parent = $parent AND post_status = 'static' ORDER BY menu_order " );
if ( $items ) {
foreach ( $items as $item ) {
$pad = str_repeat ( ' ' , $level * 3 );
2004-10-05 22:18:37 -04:00
if ( $item -> ID == $default )
2004-10-05 04:27:13 -04:00
$current = ' selected="selected"' ;
else
$current = '' ;
echo " \n \t <option value=' $item->ID ' $current > $pad $item->post_title </a></option> " ;
2004-10-05 22:18:37 -04:00
parent_dropdown ( $default , $item -> ID , $level + 1 );
2004-10-05 04:27:13 -04:00
}
} else {
return false ;
}
}
2004-10-18 00:50:08 -04:00
function user_can_access_admin_page () {
global $parent_file ;
global $pagenow ;
global $menu ;
global $submenu ;
global $user_level ;
if ( ! isset ( $parent_file )) {
$parent = $pagenow ;
} else {
$parent = $parent_file ;
}
foreach ( $menu as $menu_array ) {
//echo "parent array: " . $menu_array[2];
if ( $menu_array [ 2 ] == $parent ) {
if ( $user_level < $menu_array [ 1 ]) {
return false ;
} else {
break ;
}
}
}
if ( isset ( $submenu [ $parent ])) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( $submenu_array [ 2 ] == $pagenow ) {
if ( $user_level < $submenu_array [ 1 ]) {
return false ;
} else {
return true ;
}
}
}
}
return true ;
}
function add_options_menu ( $title , $access_level , $file ) {
global $submenu ;
$submenu [ 'options-general.php' ][] = array ( $title , $access_level , $file );
}
2004-01-27 04:33:19 -05:00
?>