2004-01-27 10:33:19 +01:00
< ? php
2005-06-19 04:51:48 +02:00
// Creates a new post from the "Write Post" form using $_POST information.
2005-06-18 21:08:38 +02:00
function write_post () {
global $user_ID ;
2005-07-17 20:59:14 +02:00
if ( ! current_user_can ( 'edit_posts' ) )
2005-06-18 21:08:38 +02:00
die ( __ ( 'You are not allowed to create posts or drafts on this blog.' ) );
// Rename.
$_POST [ 'post_content' ] = $_POST [ 'content' ];
$_POST [ 'post_excerpt' ] = $_POST [ 'excerpt' ];
$_POST [ 'post_parent' ] = $_POST [ 'parent_id' ];
2005-06-19 03:33:38 +02:00
$_POST [ 'to_ping' ] = $_POST [ 'trackback_url' ];
2005-06-18 21:08:38 +02:00
if ( ! empty ( $_POST [ 'post_author_override' ])) {
$_POST [ '$post_author' ] = ( int ) $_POST [ 'post_author_override' ];
} else if ( ! empty ( $_POST [ 'post_author' ])) {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author' ];
} else {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'user_ID' ];
}
2005-07-17 20:59:14 +02:00
if ( ( $_POST [ 'post_author' ] != $_POST [ 'user_ID' ]) && ! current_user_can ( 'edit_others_posts' ) )
2005-06-18 21:08:38 +02:00
die ( __ ( 'You cannot post as this user.' ) );
// What to do based on which button they pressed
if ( '' != $_POST [ 'saveasdraft' ]) $_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'saveasprivate' ]) $_POST [ 'post_status' ] = 'private' ;
if ( '' != $_POST [ 'publish' ]) $_POST [ 'post_status' ] = 'publish' ;
if ( '' != $_POST [ 'advanced' ]) $_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'savepage' ]) $_POST [ 'post_status' ] = 'static' ;
2005-07-17 23:08:47 +02:00
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'publish_posts' ) )
$_POST [ 'post_status' ] = 'draft' ;
2005-07-17 20:59:14 +02:00
if ( ! empty ( $_POST [ 'edit_date' ]) ) {
2005-06-18 21:08:38 +02:00
$aa = $_POST [ 'aa' ];
$mm = $_POST [ 'mm' ];
$jj = $_POST [ 'jj' ];
$hh = $_POST [ 'hh' ];
$mn = $_POST [ 'mn' ];
$ss = $_POST [ 'ss' ];
$jj = ( $jj > 31 ) ? 31 : $jj ;
$hh = ( $hh > 23 ) ? $hh - 24 : $hh ;
$mn = ( $mn > 59 ) ? $mn - 60 : $mn ;
$ss = ( $ss > 59 ) ? $ss - 60 : $ss ;
$_POST [ 'post_date' ] = " $aa - $mm - $jj $hh : $mn : $ss " ;
$_POST [ 'post_date_gmt' ] = get_gmt_from_date ( " $aa - $mm - $jj $hh : $mn : $ss " );
}
// Create the post.
$post_ID = wp_insert_post ( $_POST );
add_meta ( $post_ID );
2005-06-20 01:44:22 +02:00
return $post_ID ;
2005-06-18 21:08:38 +02:00
}
2005-06-19 04:51:48 +02:00
// Update an existing post with values provided in $_POST.
2005-06-19 03:33:38 +02:00
function edit_post () {
global $user_ID ;
2005-06-26 21:55:12 +02:00
$post_ID = ( int ) $_POST [ 'post_ID' ];
2005-06-19 03:33:38 +02:00
2005-07-17 20:59:14 +02:00
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
2005-06-19 03:33:38 +02:00
die ( __ ( 'You are not allowed to edit this post.' ) );
// Rename.
2005-06-26 21:55:12 +02:00
$_POST [ 'ID' ] = ( int ) $_POST [ 'post_ID' ];
2005-06-19 03:33:38 +02:00
$_POST [ 'post_content' ] = $_POST [ 'content' ];
$_POST [ 'post_excerpt' ] = $_POST [ 'excerpt' ];
$_POST [ 'post_parent' ] = $_POST [ 'parent_id' ];
$_POST [ 'to_ping' ] = $_POST [ 'trackback_url' ];
if ( ! empty ( $_POST [ 'post_author_override' ])) {
$_POST [ '$post_author' ] = ( int ) $_POST [ 'post_author_override' ];
} else if ( ! empty ( $_POST [ 'post_author' ])) {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author' ];
} else {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'user_ID' ];
}
2005-07-17 20:59:14 +02:00
if ( ( $_POST [ 'post_author' ] != $_POST [ 'user_ID' ]) && ! current_user_can ( 'edit_others_posts' ) )
2005-06-19 03:33:38 +02:00
die ( __ ( 'You cannot post as this user.' ) );
2005-07-17 23:08:47 +02:00
// What to do based on which button they pressed
if ( '' != $_POST [ 'saveasdraft' ]) $_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'saveasprivate' ]) $_POST [ 'post_status' ] = 'private' ;
if ( '' != $_POST [ 'publish' ]) $_POST [ 'post_status' ] = 'publish' ;
if ( '' != $_POST [ 'advanced' ]) $_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'savepage' ]) $_POST [ 'post_status' ] = 'static' ;
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'publish_posts' ) )
$_POST [ 'post_status' ] = 'draft' ;
2005-07-17 20:59:14 +02:00
if ( ! empty ( $_POST [ 'edit_date' ]) ) {
2005-06-19 03:33:38 +02:00
$aa = $_POST [ 'aa' ];
$mm = $_POST [ 'mm' ];
$jj = $_POST [ 'jj' ];
$hh = $_POST [ 'hh' ];
$mn = $_POST [ 'mn' ];
$ss = $_POST [ 'ss' ];
$jj = ( $jj > 31 ) ? 31 : $jj ;
$hh = ( $hh > 23 ) ? $hh - 24 : $hh ;
$mn = ( $mn > 59 ) ? $mn - 60 : $mn ;
$ss = ( $ss > 59 ) ? $ss - 60 : $ss ;
$_POST [ 'post_date' ] = " $aa - $mm - $jj $hh : $mn : $ss " ;
$_POST [ 'post_date_gmt' ] = get_gmt_from_date ( " $aa - $mm - $jj $hh : $mn : $ss " );
}
wp_update_post ( $_POST );
// Meta Stuff
if ( $_POST [ 'meta' ]) :
foreach ( $_POST [ 'meta' ] as $key => $value ) :
update_meta ( $key , $value [ 'key' ], $value [ 'value' ]);
endforeach ;
endif ;
if ( $_POST [ 'deletemeta' ]) :
foreach ( $_POST [ 'deletemeta' ] as $key => $value ) :
delete_meta ( $key );
endforeach ;
endif ;
add_meta ( $post_ID );
}
2005-06-26 21:55:12 +02:00
function edit_comment () {
global $user_ID ;
$comment_ID = ( int ) $_POST [ 'comment_ID' ];
$comment_post_ID = ( int ) $_POST [ 'comment_post_ID' ];
2005-07-17 20:59:14 +02:00
if ( ! current_user_can ( 'edit_post' , $comment_post_ID ) )
2005-06-26 21:55:12 +02:00
die ( __ ( 'You are not allowed to edit comments on this post, so you cannot edit this comment.' ) );
$_POST [ 'comment_author' ] = $_POST [ 'newcomment_author' ];
$_POST [ 'comment_author_email' ] = $_POST [ 'newcomment_author_email' ];
$_POST [ 'comment_author_url' ] = $_POST [ 'newcomment_author_url' ];
$_POST [ 'comment_approved' ] = $_POST [ 'comment_status' ];
$_POST [ 'comment_content' ] = $_POST [ 'content' ];
$_POST [ 'comment_ID' ] = ( int ) $_POST [ 'comment_ID' ];
2005-07-17 20:59:14 +02:00
if ( ! empty ( $_POST [ 'edit_date' ]) ) {
2005-06-26 21:55:12 +02:00
$aa = $_POST [ 'aa' ];
$mm = $_POST [ 'mm' ];
$jj = $_POST [ 'jj' ];
$hh = $_POST [ 'hh' ];
$mn = $_POST [ 'mn' ];
$ss = $_POST [ 'ss' ];
$jj = ( $jj > 31 ) ? 31 : $jj ;
$hh = ( $hh > 23 ) ? $hh - 24 : $hh ;
$mn = ( $mn > 59 ) ? $mn - 60 : $mn ;
$ss = ( $ss > 59 ) ? $ss - 60 : $ss ;
$_POST [ 'comment_date' ] = " $aa - $mm - $jj $hh : $mn : $ss " ;
}
wp_update_comment ( $_POST );
}
2005-06-19 04:51:48 +02:00
// Get an existing post and format it for editing.
function get_post_to_edit ( $id ) {
$post = get_post ( $id );
$post -> post_content = format_to_edit ( $post -> post_content );
$post -> post_content = apply_filters ( 'content_edit_pre' , $post -> post_content );
$post -> post_excerpt = format_to_edit ( $post -> post_excerpt );
$post -> post_excerpt = apply_filters ( 'excerpt_edit_pre' , $post -> post_excerpt );
$post -> post_title = format_to_edit ( $post -> post_title );
$post -> post_title = apply_filters ( 'title_edit_pre' , $post -> post_title );
if ( $post -> post_status == 'static' )
$post -> page_template = get_post_meta ( $id , '_wp_page_template' , true );
return $post ;
}
// Default post information to use when populating the "Write Post" form.
function get_default_post_to_edit () {
global $content , $excerpt , $edited_post_title ;
$post -> post_status = 'draft' ;
$post -> comment_status = get_settings ( 'default_comment_status' );
$post -> ping_status = get_settings ( 'default_ping_status' );
$post -> post_pingback = get_settings ( 'default_pingback_flag' );
$post -> post_category = get_settings ( 'default_category' );
$content = wp_specialchars ( $content );
$post -> post_content = apply_filters ( 'default_content' , $content );
$post -> post_title = apply_filters ( 'default_title' , $edited_post_title );
$post -> post_excerpt = apply_filters ( 'default_excerpt' , $excerpt );
2005-06-19 05:07:16 +02:00
$post -> page_template = 'default' ;
$post -> post_parent = 0 ;
$post -> menu_order = 0 ;
2005-06-19 04:51:48 +02:00
return $post ;
}
2005-06-26 21:55:12 +02:00
function get_comment_to_edit ( $id ) {
$comment = get_comment ( $id );
$comment -> comment_content = format_to_edit ( $comment -> comment_content );
$comment -> comment_content = apply_filters ( 'comment_edit_pre' , $comment -> comment_content );
$comment -> comment_author = format_to_edit ( $comment -> comment_author );
$comment -> comment_author_email = format_to_edit ( $comment -> comment_author_email );
$comment -> comment_author_url = format_to_edit ( $comment -> comment_author_url );
return $comment ;
}
2005-07-03 21:26:51 +02:00
function get_category_to_edit ( $id ) {
$category = get_category ( $id );
return $category ;
}
function wp_insert_category ( $catarr ) {
global $wpdb ;
extract ( $catarr );
$cat_ID = ( int ) $cat_ID ;
// Are we updating or creating?
if ( ! empty ( $cat_ID ) ) {
$update = true ;
} else {
$update = false ;
$id_result = $wpdb -> get_row ( " SHOW TABLE STATUS LIKE ' $wpdb->categories ' " );
$cat_ID = $id_result -> Auto_increment ;
}
$cat_name = wp_specialchars ( $cat_name );
if ( empty ( $category_nicename ) )
$category_nicename = sanitize_title ( $cat_name , $cat_ID );
else
$category_nicename = sanitize_title ( $category_nicename , $cat_ID );
if ( empty ( $category_description ) )
$category_description = '' ;
if ( empty ( $category_parent ) )
$category_parent = 0 ;
if ( ! $update )
$query = " INSERT INTO $wpdb->categories (cat_ID, cat_name, category_nicename, category_description, category_parent) VALUES ('0', ' $cat_name ', ' $category_nicename ', ' $category_description ', ' $cat ') " ;
else
$query = " UPDATE $wpdb->categories SET cat_name = ' $cat_name ', category_nicename = ' $category_nicename ', category_description = ' $category_description ', category_parent = ' $category_parent ' WHERE cat_ID = ' $cat_ID ' " ;
$result = $wpdb -> query ( $query );
if ( $update ) {
$rval = $wpdb -> rows_affected ;
do_action ( 'edit_category' , $cat_ID );
} else {
$rval = $wpdb -> insert_id ;
do_action ( 'create_category' , $cat_ID );
}
return $rval ;
}
function wp_update_category ( $catarr ) {
global $wpdb ;
$cat_ID = ( int ) $catarr [ 'cat_ID' ];
// First, get all of the original fields
$category = get_category ( $cat_ID , ARRAY_A );
// Escape data pulled from DB.
$category = add_magic_quotes ( $category );
// Merge old and new fields with new fields overwriting old ones.
$catarr = array_merge ( $category , $catarr );
return wp_insert_category ( $catarr );
}
function wp_delete_category ( $cat_ID ) {
global $wpdb ;
$cat_ID = ( int ) $cat_ID ;
// Don't delete the default cat.
if ( 1 == $cat_ID )
return 0 ;
$category = get_category ( $cat_ID );
$parent = $category -> category_parent ;
// Delete the category.
$wpdb -> query ( " DELETE FROM $wpdb->categories WHERE cat_ID = ' $cat_ID ' " );
// Update children to point to new parent.
$wpdb -> query ( " UPDATE $wpdb->categories SET category_parent = ' $parent ' WHERE category_parent = ' $cat_ID ' " );
// TODO: Only set categories to general if they're not in another category already
$wpdb -> query ( " UPDATE $wpdb->post2cat SET category_id='1' WHERE category_id=' $cat_ID ' " );
do_action ( 'delete_category' , $cat_ID );
return 1 ;
}
2005-07-12 17:53:13 +02:00
function wp_delete_user ( $id , $reassign = 'novalue' ) {
2005-07-05 00:03:42 +02:00
global $wpdb ;
$id = ( int ) $id ;
2005-07-12 17:53:13 +02:00
if ( $reassign == 'novalue' ) {
$post_ids = $wpdb -> get_col ( " SELECT ID FROM $wpdb->posts WHERE post_author = $id " );
if ( $post_ids ) {
$post_ids = implode ( ',' , $post_ids );
// Delete comments, *backs
$wpdb -> query ( " DELETE FROM $wpdb->comments WHERE comment_post_ID IN ( $post_ids ) " );
// Clean cats
$wpdb -> query ( " DELETE FROM $wpdb->post2cat WHERE post_id IN ( $post_ids ) " );
// Clean post_meta
$wpdb -> query ( " DELETE FROM $wpdb->postmeta WHERE post_id IN ( $post_ids ) " );
// Delete posts
$wpdb -> query ( " DELETE FROM $wpdb->posts WHERE post_author = $id " );
}
2005-07-05 00:03:42 +02:00
// Clean links
$wpdb -> query ( " DELETE FROM $wpdb->links WHERE link_owner = $id " );
2005-07-12 17:53:13 +02:00
} else {
$reassign = ( int ) $reassign ;
$wpdb -> query ( " UPDATE $wpdb->posts SET post_author = { $reassign } WHERE post_author = { $id } " );
$wpdb -> query ( " UPDATE $wpdb->links SET link_owner = { $reassign } WHERE link_owner = { $id } " );
2005-07-05 00:03:42 +02:00
}
// FINALLY, delete user
$wpdb -> query ( " DELETE FROM $wpdb->users WHERE ID = $id " );
do_action ( 'delete_user' , $id );
return true ;
}
2004-02-17 09:35:04 +01: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 10:59:47 +01:00
function selected ( $selected , $current ) {
if ( $selected == $current ) echo ' selected="selected"' ;
}
function checked ( $checked , $current ) {
if ( $checked == $current ) echo ' checked="checked"' ;
}
2004-06-16 18:40:40 +02: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
2005-02-07 03:06:57 +01:00
$cats_tmp = $wpdb -> get_results ( " SELECT cat_ID FROM $wpdb->categories WHERE category_parent = $parent ORDER BY $sort " );
2004-06-16 18:40:40 +02:00
// Now strip this down to a simple array of IDs
$cats = array ();
if ( count ( $cats_tmp ) > 0 )
{
foreach ( $cats_tmp as $cat )
{
2005-02-07 03:06:57 +01:00
$cats [] = $cat -> cat_ID ;
2004-06-16 18:40:40 +02:00
}
}
// Return the list of categories
return $cats ;
}
function get_nested_categories ( $default = 0 , $parent = 0 ) {
2004-05-24 10:22:18 +02:00
global $post_ID , $mode , $wpdb ;
2004-02-09 09:55:29 +01:00
2004-04-30 10:56:49 +02:00
if ( $post_ID ) {
2004-02-09 09:55:29 +01:00
$checked_categories = $wpdb -> get_col ( "
SELECT category_id
2004-06-16 18:40:40 +02:00
FROM $wpdb -> categories , $wpdb -> post2cat
2004-05-24 10:22:18 +02:00
WHERE $wpdb -> post2cat . category_id = cat_ID AND $wpdb -> post2cat . post_id = '$post_ID'
2004-02-09 09:55:29 +01:00
" );
2004-06-16 18:40:40 +02:00
if ( count ( $checked_categories ) == 0 )
{
// No selected categories, strange
$checked_categories [] = $default ;
}
2004-02-09 09:55:29 +01:00
} else {
$checked_categories [] = $default ;
}
2004-06-16 18:40:40 +02:00
$cats = return_categories_list ( $parent , TRUE );
2004-02-09 09:55:29 +01:00
$result = array ();
2004-06-16 18:40:40 +02: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-18 02:22:09 +02:00
$result [ $cat ][ 'cat_name' ] = get_the_category_by_ID ( $cat );
2004-02-09 09:55:29 +01:00
}
2004-06-16 18:40:40 +02:00
return $result ;
2004-02-09 09:55:29 +01: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-12-12 21:41:19 +01:00
( $category [ 'checked' ] ? ' checked="checked"' : " " ), '/> ' , wp_specialchars ( $category [ 'cat_name' ]), " </label> \n " ;
2004-02-09 09:55:29 +01:00
if ( isset ( $category [ 'children' ])) {
echo " \n <span class='cat-nest'> \n " ;
2004-05-07 23:05:02 +02:00
write_nested_categories ( $category [ 'children' ]);
2004-02-09 09:55:29 +01:00
echo " </span> \n " ;
}
}
}
function dropdown_categories ( $default = 0 ) {
write_nested_categories ( get_nested_categories ( $default ));
}
2004-01-27 10:33:19 +01:00
// Dandy new recursive multiple category stuff.
2004-02-01 03:00:26 +01:00
function cat_rows ( $parent = 0 , $level = 0 , $categories = 0 ) {
2005-07-15 04:16:45 +02:00
global $wpdb , $class ;
2005-07-09 03:27:46 +02:00
if ( ! $categories )
2004-05-24 10:22:18 +02:00
$categories = $wpdb -> get_results ( " SELECT * FROM $wpdb->categories ORDER BY cat_name " );
2004-11-18 20:51:31 +01:00
2004-01-27 10:33:19 +01:00
if ( $categories ) {
foreach ( $categories as $category ) {
2004-02-01 03:00:26 +01:00
if ( $category -> category_parent == $parent ) {
2004-12-12 21:41:19 +01:00
$category -> cat_name = wp_specialchars ( $category -> cat_name );
2004-05-24 10:22:18 +02:00
$count = $wpdb -> get_var ( " SELECT COUNT(post_id) FROM $wpdb->post2cat WHERE category_id = $category->cat_ID " );
2004-02-01 03:00:26 +01:00
$pad = str_repeat ( '— ' , $level );
2005-07-15 04:16:45 +02:00
if ( current_user_can ( 'manage_categories' ) )
2005-07-05 22:47:22 +02:00
$edit = " <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. " ), $wpdb -> escape ( $category -> cat_name )) . " ') \" class='delete'> " . __ ( 'Delete' ) . " </a> " ;
2004-11-18 20:51:31 +01:00
else
$edit = '' ;
2004-07-06 20:14:42 +02:00
$class = ( 'alternate' == $class ) ? '' : 'alternate' ;
echo " <tr class=' $class '><th scope='row'> $category->cat_ID </th><td> $pad $category->cat_name </td>
2004-02-01 03:00:26 +01:00
< td > $category -> category_description </ td >
< td > $count </ td >
2004-11-18 20:51:31 +01:00
< td > $edit </ td >
2004-02-01 03:00:26 +01:00
</ tr > " ;
2005-01-02 00:05:07 +01:00
cat_rows ( $category -> cat_ID , $level + 1 , $categories );
}
}
} else {
return false ;
}
}
function page_rows ( $parent = 0 , $level = 0 , $pages = 0 ) {
2005-07-15 04:16:45 +02:00
global $wpdb , $class , $post ;
2005-01-02 00:05:07 +01:00
if ( ! $pages )
$pages = $wpdb -> get_results ( " SELECT * FROM $wpdb->posts WHERE post_status = 'static' ORDER BY menu_order " );
if ( $pages ) {
foreach ( $pages as $post ) { start_wp ();
if ( $post -> post_parent == $parent ) {
$post -> post_title = wp_specialchars ( $post -> post_title );
$pad = str_repeat ( '— ' , $level );
$id = $post -> ID ;
$class = ( 'alternate' == $class ) ? '' : 'alternate' ;
?>
< tr class = '<?php echo $class; ?>' >
< th scope = " row " >< ? php echo $post -> ID ; ?> </th>
< td >
< ? php echo $pad ; ?> <?php the_title() ?>
</ td >
< td >< ? php the_author () ?> </td>
2005-02-12 10:32:00 +01:00
< td >< ? php echo mysql2date ( 'Y-m-d g:i a' , $post -> post_modified ); ?> </td>
2005-01-02 00:05:07 +01:00
< td >< a href = " <?php the_permalink(); ?> " rel = " permalink " class = " edit " >< ? php _e ( 'View' ); ?> </a></td>
2005-07-14 00:26:26 +02:00
< td >< ? php if ( current_user_can ( 'edit_pages' ) ) { echo " <a href='post.php?action=edit&post= $id ' class='edit'> " . __ ( 'Edit' ) . " </a> " ; } ?> </td>
< td >< ? php if ( current_user_can ( 'edit_pages' ) ) { echo " <a href='post.php?action=delete&post= $id ' class='delete' onclick= \" return confirm(' " . sprintf ( __ ( " You are about to delete this post \ '%s \ ' \\ n \ 'OK \ ' to delete, \ 'Cancel \ ' to stop. " ), the_title ( '' , '' , 0 )) . " ') \" > " . __ ( 'Delete' ) . " </a> " ; } ?> </td>
2005-01-02 00:05:07 +01:00
</ tr >
< ? php
page_rows ( $id , $level + 1 , $pages );
2004-02-01 03:00:26 +01:00
}
2004-01-27 10:33:19 +01:00
}
} else {
return false ;
}
}
2004-12-09 01:44:05 +01:00
function wp_dropdown_cats ( $currentcat = 0 , $currentparent = 0 , $parent = 0 , $level = 0 , $categories = 0 ) {
2004-05-24 10:22:18 +02:00
global $wpdb , $bgcolor ;
2004-02-01 03:00:26 +01:00
if ( ! $categories ) {
2004-05-24 10:22:18 +02:00
$categories = $wpdb -> get_results ( " SELECT * FROM $wpdb->categories ORDER BY cat_name " );
2004-02-01 03:00:26 +01:00
}
2004-01-27 10:33:19 +01:00
if ( $categories ) {
2004-02-01 03:00:26 +01:00
foreach ( $categories as $category ) { if ( $currentcat != $category -> cat_ID && $parent == $category -> category_parent ) {
2004-05-24 10:22:18 +02:00
$count = $wpdb -> get_var ( " SELECT COUNT(post_id) FROM $wpdb->post2cat WHERE category_id = $category->cat_ID " );
2004-01-27 10:33:19 +01:00
$pad = str_repeat ( '– ' , $level );
2004-12-12 21:41:19 +01:00
$category -> cat_name = wp_specialchars ( $category -> cat_name );
2004-01-27 10:33:19 +01:00
echo " \n \t <option value=' $category->cat_ID ' " ;
if ( $currentparent == $category -> cat_ID )
echo " selected='selected' " ;
echo " > $pad $category->cat_name </option> " ;
2004-02-01 03:00:26 +01:00
wp_dropdown_cats ( $currentcat , $currentparent , $category -> cat_ID , $level + 1 , $categories );
2004-01-27 10:33:19 +01:00
} }
} else {
return false ;
}
}
2004-02-05 15:28:02 +01: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 08:46:53 +02:00
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
2004-02-05 15:28:02 +01:00
} elseif ( ! function_exists ( 'imagejpeg' ) && $type [ 2 ] == 2 ) {
2004-04-23 08:46:53 +02:00
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
2004-02-05 15:28:02 +01:00
} elseif ( ! function_exists ( 'imagepng' ) && $type [ 2 ] == 3 ) {
2004-04-23 08:46:53 +02:00
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
2004-02-05 15:28:02 +01: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 );
2005-01-24 07:05:44 +01:00
@ imagecopyresampled ( $thumbnail , $image , 0 , 0 , 0 , 0 , $image_new_width , $image_new_height , $image_attr [ 0 ], $image_attr [ 1 ]);
2004-02-05 15:28:02 +01:00
// 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 08:46:53 +02:00
$error = __ ( " Thumbnail path invalid " );
2004-02-05 15:28:02 +01:00
}
} elseif ( $type [ 2 ] == 2 ) {
if ( ! imagejpeg ( $thumbnail , $thumbpath )) {
2004-04-23 08:46:53 +02:00
$error = __ ( " Thumbnail path invalid " );
2004-02-05 15:28:02 +01:00
}
} elseif ( $type [ 2 ] == 3 ) {
if ( ! imagepng ( $thumbnail , $thumbpath )) {
2004-04-23 08:46:53 +02:00
$error = __ ( " Thumbnail path invalid " );
2004-02-05 15:28:02 +01:00
}
}
}
}
if ( ! empty ( $error ))
{
return $error ;
}
else
{
return 1 ;
}
}
2004-03-23 19:02:05 +01:00
// Some postmeta stuff
function has_meta ( $postid ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-03-23 19:02:05 +01:00
return $wpdb -> get_results ( "
SELECT meta_key , meta_value , meta_id , post_id
2004-05-24 10:22:18 +02:00
FROM $wpdb -> postmeta
2004-05-05 10:18:30 +02:00
WHERE post_id = '$postid'
2004-03-23 19:02:05 +01:00
ORDER BY meta_key , meta_id " ,ARRAY_A);
}
function list_meta ( $meta ) {
global $post_ID ;
// Exit if no meta
2004-12-09 05:12:20 +01:00
if ( ! $meta ) return ;
$count = 0 ;
2004-04-28 04:23:46 +02:00
?>
2004-04-28 21:49:27 +02:00
< table id = 'meta-list' cellpadding = " 3 " >
2004-04-28 04:23:46 +02:00
< tr >
< th >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
< th colspan = '2' >< ? php _e ( 'Action' ) ?> </th>
</ tr >
< ? php
2004-03-23 19:02:05 +01:00
foreach ( $meta as $entry ) {
2004-12-09 05:12:20 +01:00
++ $count ;
if ( $count % 2 ) $style = 'alternate' ;
else $style = '' ;
if ( '_' == $entry [ 'meta_key' ]{ 0 } ) $style .= ' hidden' ;
2004-04-28 04:23:46 +02:00
echo "
2004-12-09 05:12:20 +01:00
< tr class = '$style' >
2004-04-28 21:49:27 +02: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-28 04:23:46 +02:00
</ tr >
" ;
2004-03-23 19:02:05 +01:00
}
2004-04-28 04:23:46 +02:00
echo "
</ table >
" ;
2004-03-23 19:02:05 +01:00
}
// Get a list of previously defined keys
function get_meta_keys () {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-03-23 19:02:05 +01:00
$keys = $wpdb -> get_col ( "
SELECT meta_key
2004-05-24 10:22:18 +02:00
FROM $wpdb -> postmeta
2004-03-23 19:02:05 +01:00
GROUP BY meta_key
ORDER BY meta_key " );
return $keys ;
}
function meta_form () {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-04-28 06:49:16 +02:00
$keys = $wpdb -> get_col ( "
SELECT meta_key
2004-05-24 10:22:18 +02:00
FROM $wpdb -> postmeta
2004-04-28 06:49:16 +02:00
GROUP BY meta_key
ORDER BY meta_id DESC
LIMIT 10 " );
2004-03-23 19:02:05 +01:00
?>
2004-04-28 06:49:16 +02:00
< h3 >< ? php _e ( 'Add a new custom field to this post:' ) ?> </h3>
2004-04-28 21:49:27 +02:00
< table cellspacing = " 3 " cellpadding = " 3 " >
2004-04-28 04:23:46 +02:00
< tr >
< th colspan = " 2 " >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
</ tr >
< tr valign = " top " >
2004-05-20 13:32:14 +02:00
< td align = " right " width = " 18% " >
< ? php if ( $keys ) : ?>
< select id = " metakeyselect " name = " metakeyselect " tabindex = " 7 " >
2004-12-04 07:53:10 +01:00
< option value = " #NONE# " >< ? php _e ( '- Select -' ); ?> </option>
2004-03-23 19:02:05 +01:00
< ? php
foreach ( $keys as $key ) {
2004-04-28 04:23:46 +02:00
echo " \n \t <option value=' $key '> $key </option> " ;
2004-03-23 19:02:05 +01:00
}
?>
2004-12-04 07:53:10 +01:00
</ select > < ? php _e ( 'or' ); ?>
2004-05-20 13:32:14 +02:00
< ? php endif ; ?>
</ td >
2004-04-28 21:49:27 +02:00
< td >< input type = " text " id = " metakeyinput " name = " metakeyinput " tabindex = " 7 " /></ td >
2004-12-09 05:12:20 +01:00
< td >< textarea id = " metavalue " name = " metavalue " rows = " 3 " cols = " 25 " tabindex = " 8 " ></ textarea ></ td >
2004-04-28 04:23:46 +02:00
</ tr >
2004-03-23 19:02:05 +01:00
2004-04-28 04:23:46 +02:00
</ table >
2004-12-09 05:12:20 +01:00
< p class = " submit " >< input type = " submit " name = " updatemeta " tabindex = " 9 " value = " <?php _e('Add Custom Field »') ?> " /></ p >
2004-03-23 19:02:05 +01:00
< ? php
}
function add_meta ( $post_ID ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-03-23 19:02:05 +01:00
2004-04-28 04:23:46 +02: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 19:02:05 +01:00
2004-04-12 19:31:37 +02:00
if ( ! empty ( $metavalue ) && ((( '#NONE#' != $metakeyselect ) && ! empty ( $metakeyselect )) || ! empty ( $metakeyinput ))) {
2004-03-23 19:02:05 +01: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 10:22:18 +02:00
INSERT INTO $wpdb -> postmeta
2004-03-23 19:02:05 +01:00
( post_id , meta_key , meta_value )
VALUES ( '$post_ID' , '$metakey' , '$metavalue' )
" );
}
} // add_meta
2004-04-28 06:49:16 +02:00
function delete_meta ( $mid ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-04-28 04:23:46 +02:00
2004-05-24 10:22:18 +02:00
$result = $wpdb -> query ( " DELETE FROM $wpdb->postmeta WHERE meta_id = ' $mid ' " );
2004-03-23 19:02:05 +01:00
}
2004-04-28 06:49:16 +02:00
function update_meta ( $mid , $mkey , $mvalue ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-04-28 06:49:16 +02:00
2004-05-24 10:22:18 +02:00
return $wpdb -> query ( " UPDATE $wpdb->postmeta SET meta_key = ' $mkey ', meta_value = ' $mvalue ' WHERE meta_id = ' $mid ' " );
2004-04-28 06:49:16 +02:00
}
2005-03-10 10:50:26 +01:00
function touch_time ( $edit = 1 , $for_post = 1 ) {
2005-07-17 21:02:05 +02:00
global $month , $post , $comment ;
if ( $for_post && ( 'draft' == $post -> post_status ) ) {
2004-04-30 10:56:49 +02:00
$checked = 'checked="checked" ' ;
$edit = false ;
} else {
$checked = ' ' ;
}
2004-08-01 10:28:56 +02: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 10:56:49 +02:00
$time_adj = time () + ( get_settings ( 'gmt_offset' ) * 3600 );
2005-07-17 21:02:05 +02:00
$post_date = ( $for_post ) ? $post -> post_date : $comment -> comment_date ;
2004-04-30 10:56:49 +02:00
$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 10:28:56 +02:00
}
?>
2004-04-30 10:56:49 +02:00
</ select >
2004-08-01 10:28:56 +02:00
< input type = " text " name = " jj " value = " <?php echo $jj ; ?> " size = " 2 " maxlength = " 2 " />
2004-04-30 10:56:49 +02: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 10:28:56 +02:00
< input type = " text " name = " mn " value = " <?php echo $mn ?> " size = " 2 " maxlength = " 2 " />
2005-03-10 10:50:26 +01:00
< input type = " hidden " name = " ss " value = " <?php echo $ss ?> " size = " 2 " maxlength = " 2 " />
< ? php _e ( 'Existing timestamp' ); ?> :
< ? php
// We might need to readjust to display proper existing timestamp
2005-07-17 21:02:05 +02:00
if ( $for_post && ( 'draft' == $post -> post_status ) ) {
2005-03-10 10:50:26 +01:00
$jj = mysql2date ( 'd' , $post_date );
$mm = mysql2date ( 'm' , $post_date );
$aa = mysql2date ( 'Y' , $post_date );
$hh = mysql2date ( 'H' , $post_date );
$mn = mysql2date ( 'i' , $post_date );
$ss = mysql2date ( 's' , $post_date );
}
echo " { $month [ $mm ] } $jj , $aa @ $hh : $mn " ; ?>
</ fieldset >
2004-04-30 10:56:49 +02:00
< ? php
}
2004-05-17 21:40:56 +02:00
function check_admin_referer () {
2005-05-09 20:26:53 +02:00
$adminurl = strtolower ( get_settings ( 'siteurl' ) ) . '/wp-admin' ;
$referer = strtolower ( $_SERVER [ 'HTTP_REFERER' ] );
if ( ! strstr ( $referer , $adminurl ) )
die ( __ ( 'Sorry, you need to <a href="http://codex.wordpress.org/Enable_Sending_Referrers">enable sending referrers</a> for this feature to work.' ));
do_action ( 'check_admin_referer' );
2004-05-17 21:40:56 +02:00
}
2004-07-28 01:37:45 +02: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-27 04:32:51 +02: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-28 01:37:45 +02: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-27 04:32:51 +02:00
$result = array ();
2004-07-28 01:37:45 +02:00
2004-09-27 04:32:51 +02: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-28 01:37:45 +02:00
}
2004-10-06 04:18:37 +02:00
function save_mod_rewrite_rules () {
2004-12-03 03:38:11 +01:00
global $is_apache , $wp_rewrite ;
2004-12-23 01:53:56 +01:00
$home_path = get_home_path ();
2004-10-06 04:18:37 +02:00
2004-12-27 23:30:52 +01:00
if ( ! $wp_rewrite -> using_mod_rewrite_permalinks ())
return ;
if ( ! (( ! file_exists ( $home_path . '.htaccess' ) && is_writable ( $home_path )) || is_writable ( $home_path . '.htaccess' )) )
return ;
if ( ! $is_apache )
return ;
$rules = explode ( " \n " , $wp_rewrite -> mod_rewrite_rules ());
insert_with_markers ( $home_path . '.htaccess' , 'WordPress' , $rules );
2004-10-06 04:18:37 +02:00
}
2004-09-09 19:51:33 +02: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 " >
< script src = " quicktags.js " type = " text/javascript " ></ script >
< script type = " text/javascript " > edToolbar (); </ script >
' ;
echo '</div>' ;
endif ;
}
2004-09-16 20:09:32 +02: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 08:20:52 +02:00
do_action ( 'switch_theme' , 'Default' );
2004-09-16 20:09:32 +02:00
return false ;
}
if (( $stylesheet != 'default' ) && ( ! file_exists ( " $theme_root / $stylesheet /style.css " ))) {
update_option ( 'template' , 'default' );
update_option ( 'stylesheet' , 'default' );
2004-10-06 08:20:52 +02:00
do_action ( 'switch_theme' , 'Default' );
2004-09-16 20:09:32 +02:00
return false ;
}
return true ;
}
2004-10-25 01:48:51 +02:00
function get_broken_themes () {
global $wp_broken_themes ;
get_themes ();
return $wp_broken_themes ;
}
2004-10-06 07:11:11 +02:00
function get_page_templates () {
$themes = get_themes ();
$theme = get_current_theme ();
$templates = $themes [ $theme ][ 'Template Files' ];
$page_templates = array ();
2005-03-23 02:14:05 +01:00
if ( is_array ( $templates ) ) {
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 );
2004-10-06 07:11:11 +02:00
2005-03-23 02:14:05 +01:00
$name = $name [ 1 ];
$description = $description [ 1 ];
2004-10-06 07:11:11 +02:00
2005-03-23 02:14:05 +01:00
if ( ! empty ( $name )) {
$page_templates [ trim ( $name )] = basename ( $template );
}
2004-10-06 07:11:11 +02:00
}
}
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-06 04:18:37 +02:00
function parent_dropdown ( $default = 0 , $parent = 0 , $level = 0 ) {
2004-11-24 01:12:46 +01:00
global $wpdb , $post_ID ;
2004-10-05 10:27:13 +02:00
$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 " );
2004-11-24 01:12:46 +01:00
2004-10-05 10:27:13 +02:00
if ( $items ) {
foreach ( $items as $item ) {
2004-11-24 01:12:46 +01:00
// A page cannot be it's own parent.
if ( ! empty ( $post_ID )) {
if ( $item -> ID == $post_ID ) {
continue ;
}
}
2004-10-05 10:27:13 +02:00
$pad = str_repeat ( ' ' , $level * 3 );
2004-10-06 04:18:37 +02:00
if ( $item -> ID == $default )
2004-10-05 10:27:13 +02:00
$current = ' selected="selected"' ;
else
$current = '' ;
2004-12-12 07:31:01 +01:00
echo " \n \t <option value=' $item->ID ' $current > $pad $item->post_title </option> " ;
2004-10-06 04:18:37 +02:00
parent_dropdown ( $default , $item -> ID , $level + 1 );
2004-10-05 10:27:13 +02:00
}
} else {
return false ;
}
}
2004-10-18 06:50:08 +02:00
function user_can_access_admin_page () {
global $pagenow ;
global $menu ;
global $submenu ;
2004-12-08 23:32:49 +01:00
$parent = get_admin_page_parent ();
2004-10-18 06:50:08 +02:00
foreach ( $menu as $menu_array ) {
//echo "parent array: " . $menu_array[2];
if ( $menu_array [ 2 ] == $parent ) {
2005-07-13 18:04:14 +02:00
if ( ! current_user_can ( $menu_array [ 1 ]) ) {
2004-10-18 06:50:08 +02:00
return false ;
} else {
break ;
}
}
}
if ( isset ( $submenu [ $parent ])) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( $submenu_array [ 2 ] == $pagenow ) {
2005-07-13 18:04:14 +02:00
if ( ! current_user_can ( $submenu_array [ 1 ]) ) {
2004-10-18 06:50:08 +02:00
return false ;
} else {
return true ;
}
}
}
}
return true ;
}
2004-10-19 05:03:06 +02:00
function get_admin_page_title () {
global $title ;
2005-01-30 08:34:03 +01:00
global $menu ;
2004-10-18 06:50:08 +02:00
global $submenu ;
2004-10-19 05:03:06 +02:00
global $pagenow ;
global $plugin_page ;
if ( isset ( $title ) && ! empty ( $title )) {
return $title ;
}
2005-01-30 08:34:03 +01:00
$parent = get_admin_page_parent ();
if ( empty ( $parent )) {
foreach ( $menu as $menu_array ) {
if ( isset ( $menu_array [ 3 ])) {
if ( $menu_array [ 2 ] == $pagenow ) {
$title = $menu_array [ 3 ];
return $menu_array [ 3 ];
} else if ( isset ( $plugin_page ) && ( $plugin_page == $menu_array [ 2 ])) {
$title = $menu_array [ 3 ];
return $menu_array [ 3 ];
}
}
}
} else {
foreach ( array_keys ( $submenu ) as $parent ) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( isset ( $submenu_array [ 3 ])) {
if ( $submenu_array [ 2 ] == $pagenow ) {
$title = $submenu_array [ 3 ];
return $submenu_array [ 3 ];
} else if ( isset ( $plugin_page ) && ( $plugin_page == $submenu_array [ 2 ])) {
$title = $submenu_array [ 3 ];
return $submenu_array [ 3 ];
}
2004-10-19 05:03:06 +02:00
}
}
}
}
return '' ;
}
function get_admin_page_parent () {
global $parent_file ;
2005-02-25 17:11:27 +01:00
global $menu ;
2004-10-19 05:03:06 +02:00
global $submenu ;
global $pagenow ;
global $plugin_page ;
if ( isset ( $parent_file ) && ! empty ( $parent_file )) {
return $parent_file ;
}
2005-02-25 17:11:27 +01:00
if ( $pagenow == 'admin.php' && isset ( $plugin_page )) {
foreach ( $menu as $parent_menu ) {
if ( $parent_menu [ 2 ] == $plugin_page ) {
$parent_file = $plugin_page ;
return $plugin_page ;
}
}
}
2004-10-19 05:03:06 +02:00
foreach ( array_keys ( $submenu ) as $parent ) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( $submenu_array [ 2 ] == $pagenow ) {
$parent_file = $parent ;
return $parent ;
} else if ( isset ( $plugin_page ) && ( $plugin_page == $submenu_array [ 2 ])) {
$parent_file = $parent ;
return $parent ;
}
}
}
$parent_file = '' ;
return '' ;
}
2005-02-25 17:11:27 +01:00
function add_menu_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
2005-02-07 02:15:06 +01:00
global $menu , $admin_page_hooks ;
2004-11-26 02:50:37 +01:00
2004-11-28 01:33:04 +01:00
$file = plugin_basename ( $file );
2004-11-26 02:50:37 +01:00
$menu [] = array ( $menu_title , $access_level , $file , $page_title );
2005-02-07 02:15:06 +01:00
$admin_page_hooks [ $file ] = sanitize_title ( $menu_title );
2005-02-25 17:11:27 +01:00
$hookname = get_plugin_page_hookname ( $file , '' );
if ( ! empty ( $function ) && ! empty ( $hookname ) )
add_action ( $hookname , $function );
return $hookname ;
2004-11-26 02:50:37 +01:00
}
2005-02-07 02:15:06 +01:00
function add_submenu_page ( $parent , $page_title , $menu_title , $access_level , $file , $function = '' ) {
2004-10-19 05:03:06 +02:00
global $submenu ;
2004-12-04 06:02:07 +01:00
global $menu ;
2004-10-19 05:03:06 +02:00
2004-12-04 06:02:07 +01:00
$parent = plugin_basename ( $parent );
2004-11-28 01:33:04 +01:00
$file = plugin_basename ( $file );
2004-10-19 05:03:06 +02:00
2004-12-04 06:02:07 +01:00
// If the parent doesn't already have a submenu, add a link to the parent
// as the first item in the submenu. If the submenu file is the same as the
// parent file someone is trying to link back to the parent manually. In
// this case, don't automatically add a link back to avoid duplication.
if ( ! isset ( $submenu [ $parent ]) && $file != $parent ) {
foreach ( $menu as $parent_menu ) {
if ( $parent_menu [ 2 ] == $parent ) {
$submenu [ $parent ][] = $parent_menu ;
}
}
}
2004-11-26 02:50:37 +01:00
$submenu [ $parent ][] = array ( $menu_title , $access_level , $file , $page_title );
2005-02-07 02:15:06 +01:00
$hookname = get_plugin_page_hookname ( $file , $parent );
if ( ! empty ( $function ) && ! empty ( $hookname ) )
add_action ( $hookname , $function );
return $hookname ;
2004-10-18 06:50:08 +02:00
}
2005-02-07 02:15:06 +01:00
function add_options_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
return add_submenu_page ( 'options-general.php' , $page_title , $menu_title , $access_level , $file , $function );
2004-11-26 02:50:37 +01:00
}
2005-02-07 02:15:06 +01:00
function add_management_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
return add_submenu_page ( 'edit.php' , $page_title , $menu_title , $access_level , $file , $function );
2004-11-26 02:50:37 +01:00
}
2004-11-17 04:15:44 +01:00
2004-12-30 19:05:46 +01:00
function validate_file ( $file , $allowed_files = '' ) {
if ( false !== strpos ( $file , './' ))
return 1 ;
if ( ':' == substr ( $file , 1 , 1 ))
return 2 ;
if ( ! empty ( $allowed_files ) && ( ! in_array ( $file , $allowed_files )) )
return 3 ;
return 0 ;
}
2004-11-17 04:15:44 +01:00
function validate_file_to_edit ( $file , $allowed_files = '' ) {
2004-12-30 19:05:46 +01:00
$file = stripslashes ( $file );
$code = validate_file ( $file , $allowed_files );
if ( ! $code )
return $file ;
switch ( $code ) {
case 1 :
2004-11-17 04:15:44 +01:00
die ( __ ( 'Sorry, can’t edit files with ".." in the name. If you are trying to edit a file in your WordPress home directory, you can just type the name of the file in.' ));
2004-12-30 19:05:46 +01:00
case 2 :
2004-11-17 04:15:44 +01:00
die ( __ ( 'Sorry, can’t call files with their real path.' ));
2004-12-30 19:05:46 +01:00
case 3 :
2004-11-17 04:15:44 +01:00
die ( __ ( 'Sorry, that file cannot be edited.' ));
}
}
2004-12-23 01:53:56 +01:00
function get_home_path () {
2004-11-17 04:15:44 +01:00
$home = get_settings ( 'home' );
2004-12-23 01:53:56 +01:00
if ( $home != '' && $home != get_settings ( 'siteurl' ) ) {
$home_path = parse_url ( $home );
2005-02-01 07:59:44 +01:00
$home_path = $home_path [ 'path' ];
2004-12-23 01:53:56 +01:00
$root = str_replace ( $_SERVER [ " PHP_SELF " ], '' , $_SERVER [ " SCRIPT_FILENAME " ]);
2005-02-01 07:59:44 +01:00
$home_path = trailingslashit ( $root . $home_path );
2004-12-23 01:53:56 +01:00
} else {
$home_path = ABSPATH ;
}
return $home_path ;
}
function get_real_file_to_edit ( $file ) {
2004-12-24 02:34:47 +01:00
if ( 'index.php' == $file ||
2004-12-23 01:53:56 +01:00
'.htaccess' == $file ) {
$real_file = get_home_path () . $file ;
2004-11-17 04:15:44 +01:00
} else {
$real_file = ABSPATH . $file ;
}
return $real_file ;
}
2004-12-09 05:12:20 +01:00
$wp_file_descriptions =
array (
'index.php' => __ ( 'Main Template' ),
'style.css' => __ ( 'Stylesheet' ),
'comments.php' => __ ( 'Comments Template' ),
'comments-popup.php' => __ ( 'Popup Comments Template' ),
'footer.php' => __ ( 'Footer Template' ),
'header.php' => __ ( 'Header Template' ),
'sidebar.php' => __ ( 'Sidebar Template' ),
'archive.php' => __ ( 'Archive Template' ),
'category.php' => __ ( 'Category Template' ),
'page.php' => __ ( 'Page Template' ),
'search.php' => __ ( 'Search Template' ),
'single.php' => __ ( 'Post Template' ),
'404.php' => __ ( '404 Template' ),
'my-hacks.php' => __ ( 'my-hacks.php (legacy hacks support)' ),
2005-01-19 16:23:38 +01:00
'.htaccess' => __ ( '.htaccess (for rewrite rules)' ),
// Deprecated files
'wp-layout.css' => __ ( 'Stylesheet' ),
'wp-comments.php' => __ ( 'Comments Template' ),
'wp-comments-popup.php' => __ ( 'Popup Comments Template' )
2004-12-09 05:12:20 +01:00
);
2004-11-17 04:15:44 +01:00
function get_file_description ( $file ) {
global $wp_file_descriptions ;
2005-02-14 05:24:25 +01:00
if ( isset ( $wp_file_descriptions [ basename ( $file )] ) ) {
return $wp_file_descriptions [ basename ( $file )];
2005-02-15 04:32:43 +01:00
} elseif ( file_exists ( ABSPATH . $file ) ) {
2005-02-14 05:24:25 +01:00
$template_data = implode ( '' , file ( ABSPATH . $file ));
if ( preg_match ( " |Template Name:(.*)|i " , $template_data , $name ) )
return $name [ 1 ];
2004-11-17 04:15:44 +01:00
}
2005-02-14 05:24:25 +01:00
return basename ( $file );
2004-11-17 04:15:44 +01:00
}
function update_recently_edited ( $file ) {
$oldfiles = ( array ) get_option ( 'recently_edited' );
if ( $oldfiles ) {
$oldfiles = array_reverse ( $oldfiles );
$oldfiles [] = $file ;
$oldfiles = array_reverse ( $oldfiles );
$oldfiles = array_unique ( $oldfiles );
if ( 5 < count ( $oldfiles ) )
array_pop ( $oldfiles );
} else {
$oldfiles [] = $file ;
}
update_option ( 'recently_edited' , $oldfiles );
}
2004-11-26 03:29:45 +01:00
function get_plugin_data ( $plugin_file ) {
$plugin_data = implode ( '' , file ( $plugin_file ));
preg_match ( " |Plugin Name:(.*)|i " , $plugin_data , $plugin_name );
preg_match ( " |Plugin URI:(.*)|i " , $plugin_data , $plugin_uri );
preg_match ( " |Description:(.*)|i " , $plugin_data , $description );
preg_match ( " |Author:(.*)|i " , $plugin_data , $author_name );
preg_match ( " |Author URI:(.*)|i " , $plugin_data , $author_uri );
if ( preg_match ( " |Version:(.*)|i " , $plugin_data , $version ) )
$version = $version [ 1 ];
else
$version = '' ;
$description = wptexturize ( $description [ 1 ]);
$name = $plugin_name [ 1 ];
$name = trim ( $name );
$plugin = $name ;
if ( '' != $plugin_uri [ 1 ] && '' != $name ) {
2005-03-11 04:41:04 +01:00
$plugin = '<a href="' . $plugin_uri [ 1 ] . '" title="' . __ ( 'Visit plugin homepage' ) . '">' . $plugin . '</a>' ;
2004-11-26 03:29:45 +01:00
}
if ( '' == $author_uri [ 1 ]) {
$author = $author_name [ 1 ];
} else {
2005-03-11 04:41:04 +01:00
$author = '<a href="' . $author_uri [ 1 ] . '" title="' . __ ( 'Visit author homepage' ) . '">' . $author_name [ 1 ] . '</a>' ;
2004-11-26 03:29:45 +01:00
}
return array ( 'Name' => $name , 'Title' => $plugin , 'Description' => $description , 'Author' => $author , 'Version' => $version , 'Template' => $template [ 1 ]);
}
function get_plugins () {
global $wp_plugins ;
if ( isset ( $wp_plugins )) {
return $wp_plugins ;
}
$wp_plugins = array ();
$plugin_loc = 'wp-content/plugins' ;
$plugin_root = ABSPATH . $plugin_loc ;
// Files in wp-content/plugins directory
$plugins_dir = @ dir ( $plugin_root );
if ( $plugins_dir ) {
while (( $file = $plugins_dir -> read ()) !== false ) {
2004-11-28 01:33:04 +01:00
if ( preg_match ( '|^\.+$|' , $file ) )
continue ;
if ( is_dir ( $plugin_root . '/' . $file )) {
$plugins_subdir = @ dir ( $plugin_root . '/' . $file );
if ( $plugins_subdir ) {
while (( $subfile = $plugins_subdir -> read ()) !== false ) {
if ( preg_match ( '|^\.+$|' , $subfile ) )
continue ;
if ( preg_match ( '|\.php$|' , $subfile ) )
$plugin_files [] = " $file / $subfile " ;
}
}
} else {
if ( preg_match ( '|\.php$|' , $file ) )
$plugin_files [] = $file ;
}
2004-11-26 03:29:45 +01:00
}
}
if ( ! $plugins_dir || ! $plugin_files ) {
return $wp_plugins ;
}
sort ( $plugin_files );
foreach ( $plugin_files as $plugin_file ) {
$plugin_data = get_plugin_data ( " $plugin_root / $plugin_file " );
if ( empty ( $plugin_data [ 'Name' ])) {
continue ;
}
2004-11-28 01:33:04 +01:00
$wp_plugins [ plugin_basename ( $plugin_file )] = $plugin_data ;
2004-11-26 03:29:45 +01:00
}
return $wp_plugins ;
}
2005-02-07 02:15:06 +01:00
function get_plugin_page_hookname ( $plugin_page , $parent_page ) {
global $admin_page_hooks ;
2005-02-25 17:11:27 +01:00
$parent = get_admin_page_parent ();
if ( empty ( $parent_page ) || 'admin.php' == $parent_page ) {
if ( isset ( $admin_page_hooks [ $plugin_page ]) )
$page_type = 'toplevel' ;
else if ( isset ( $admin_page_hooks [ $parent ]) )
$page_type = $admin_page_hooks [ $parent ];
} else if ( isset ( $admin_page_hooks [ $parent_page ]) ) {
2005-02-07 02:15:06 +01:00
$page_type = $admin_page_hooks [ $parent_page ];
2005-02-25 17:11:27 +01:00
} else {
2005-02-07 02:15:06 +01:00
$page_type = 'admin' ;
2005-02-25 17:11:27 +01:00
}
2005-02-07 02:15:06 +01:00
$plugin_name = preg_replace ( '!\.php!' , '' , $plugin_page );
return $page_type . '_page_' . $plugin_name ;
}
function get_plugin_page_hook ( $plugin_page , $parent_page ) {
global $wp_filter ;
2005-02-25 17:11:27 +01:00
2005-02-07 02:15:06 +01:00
$hook = get_plugin_page_hookname ( $plugin_page , $parent_page );
if ( isset ( $wp_filter [ $hook ]) )
return $hook ;
else
return '' ;
}
2005-04-19 04:16:57 +02:00
function pimp_firefox () {
if ( strstr ( $_SERVER [ 'HTTP_USER_AGENT' ], 'Firefox' ) )
return ;
$getit = __ ( 'WordPress recommends the open-source Firefox browser' );
echo '
< p id = " firefoxlink " style = " text-align: center; " >< a href = " http://spreadfirefox.com/community/?q=affiliates&id=2490&t=1 " title = " ' . $getit . ' " >< img src = " ../wp-images/get-firefox.png " alt = " Get Firefox " /></ a ></ p >
' ;
}
add_action ( 'admin_footer' , 'pimp_firefox' );
2005-07-09 00:59:15 +02:00
function documentation_link ( $for ) {
return ;
}
2005-04-19 04:16:57 +02:00
?>