2004-01-27 10:33:19 +01:00
< ? php
2005-06-18 21:08:38 +02:00
function write_post () {
2006-08-11 05:54:45 +02:00
$result = wp_write_post ();
2006-11-18 07:09:48 +01:00
if ( is_wp_error ( $result ) )
2006-08-11 05:54:45 +02:00
wp_die ( $result -> get_error_message () );
else
return $result ;
}
// Creates a new post from the "Write Post" form using $_POST information.
function wp_write_post () {
2005-06-18 21:08:38 +02:00
global $user_ID ;
2006-02-11 10:56:02 +01:00
if ( 'page' == $_POST [ 'post_type' ] ) {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_pages' ) )
return new WP_Error ( 'edit_pages' , __ ( 'You are not allowed to create pages on this blog.' ) );
2006-02-11 10:56:02 +01:00
} else {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_posts' ) )
return new WP_Error ( 'edit_posts' , __ ( 'You are not allowed to create posts or drafts on this blog.' ) );
2006-02-11 10:56:02 +01:00
}
2005-06-18 21:08:38 +02:00
2007-01-18 04:32:54 +01:00
// Check for autosave collisions
2007-02-15 02:03:06 +01:00
$temp_id = false ;
2007-01-18 04:32:54 +01:00
if ( isset ( $_POST [ 'temp_ID' ]) ) {
$temp_id = ( int ) $_POST [ 'temp_ID' ];
if ( ! $draft_ids = get_user_option ( 'autosave_draft_ids' ) )
$draft_ids = array ();
foreach ( $draft_ids as $temp => $real )
if ( time () + $temp > 86400 ) // 1 day: $temp is equal to -1 * time( then )
unset ( $draft_ids [ $temp ]);
if ( isset ( $draft_ids [ $temp_id ]) ) { // Edit, don't write
$_POST [ 'post_ID' ] = $draft_ids [ $temp_id ];
unset ( $_POST [ 'temp_ID' ]);
update_user_option ( $user_ID , 'autosave_draft_ids' , $draft_ids );
return edit_post ();
}
}
2005-06-18 21:08:38 +02:00
// Rename.
2005-09-18 21:44:14 +02:00
$_POST [ 'post_content' ] = $_POST [ 'content' ];
$_POST [ 'post_excerpt' ] = $_POST [ 'excerpt' ];
2005-06-18 21:08:38 +02:00
$_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
2006-11-18 07:09:48 +01:00
if ( ! empty ( $_POST [ 'post_author_override' ] ) ) {
2005-10-01 00:45:06 +02:00
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author_override' ];
2006-02-11 10:56:02 +01:00
} else {
2006-11-18 07:09:48 +01:00
if ( ! empty ( $_POST [ 'post_author' ] ) ) {
2005-09-18 21:44:14 +02:00
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author' ];
} else {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'user_ID' ];
}
2006-02-11 10:56:02 +01:00
}
2006-11-18 07:09:48 +01:00
if ( $_POST [ 'post_author' ] != $_POST [ 'user_ID' ] ) {
2006-02-12 08:53:23 +01:00
if ( 'page' == $_POST [ 'post_type' ] ) {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_others_pages' ) )
2006-12-22 00:06:18 +01:00
return new WP_Error ( 'edit_others_pages' , __ ( 'You are not allowed to create pages as this user.' ) );
2006-02-11 10:56:02 +01:00
} else {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_others_posts' ) )
2006-12-22 00:06:18 +01:00
return new WP_Error ( 'edit_others_posts' , __ ( 'You are not allowed to post as this user.' ) );
2006-02-12 08:53:23 +01:00
2006-02-11 10:56:02 +01:00
}
}
2005-06-18 21:08:38 +02:00
// What to do based on which button they pressed
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'saveasdraft' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'draft' ;
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'saveasprivate' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'private' ;
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'publish' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'publish' ;
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'advanced' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'draft' ;
2005-07-17 23:08:47 +02:00
2006-02-11 10:56:02 +01:00
if ( 'page' == $_POST [ 'post_type' ] ) {
2006-11-18 07:09:48 +01:00
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'publish_pages' ) )
2006-02-12 08:53:23 +01:00
$_POST [ 'post_status' ] = 'draft' ;
2006-02-11 10:56:02 +01:00
} else {
2006-11-18 07:09:48 +01:00
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'publish_posts' ) )
2006-02-11 10:56:02 +01:00
$_POST [ 'post_status' ] = 'draft' ;
}
2005-12-05 05:04:23 +01:00
2006-11-18 07:09:48 +01:00
if ( ! isset ( $_POST [ 'comment_status' ] ))
2006-02-18 01:16:41 +01:00
$_POST [ 'comment_status' ] = 'closed' ;
2006-11-18 07:09:48 +01:00
if ( ! isset ( $_POST [ 'ping_status' ] ))
2006-02-18 01:16:41 +01:00
$_POST [ 'ping_status' ] = 'closed' ;
2006-11-18 07:09:48 +01: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' ];
2006-11-18 07:09:48 +01:00
$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' ] = sprintf ( " %04d-%02d-%02d %02d:%02d:%02d " , $aa , $mm , $jj , $hh , $mn , $ss );
$_POST [ 'post_date_gmt' ] = get_gmt_from_date ( $_POST [ 'post_date' ] );
2005-09-18 21:44:14 +02:00
}
2005-06-18 21:08:38 +02:00
// Create the post.
2007-01-18 04:32:54 +01:00
$post_ID = wp_insert_post ( $_POST );
2006-11-18 07:09:48 +01:00
add_meta ( $post_ID );
2005-06-20 01:44:22 +02:00
2005-11-15 23:55:24 +01:00
// Reunite any orphaned attachments with their parent
2007-02-15 02:03:06 +01:00
if ( ! $draft_ids = get_user_option ( 'autosave_draft_ids' ) )
$draft_ids = array ();
if ( $draft_temp_id = array_search ( $post_ID , $draft_ids ) )
relocate_children ( $draft_temp_id , $post_ID );
if ( $temp_id && $temp_id != $draft_temp_id )
relocate_children ( $temp_id , $post_ID );
2007-01-18 04:32:54 +01:00
// Update autosave collision detection
if ( $temp_id ) {
$draft_ids [ $temp_id ] = $post_ID ;
update_user_option ( $user_ID , 'autosave_draft_ids' , $draft_ids );
}
2005-09-27 01:55:36 +02:00
2005-11-18 10:25:47 +01:00
// Now that we have an ID we can fix any attachment anchor hrefs
2006-11-18 07:09:48 +01:00
fix_attachment_links ( $post_ID );
2005-11-18 10:25:47 +01:00
2005-06-20 01:44:22 +02:00
return $post_ID ;
2005-06-18 21:08:38 +02:00
}
2005-09-27 01:55:36 +02:00
// Move child posts to a new parent
2006-11-18 07:09:48 +01:00
function relocate_children ( $old_ID , $new_ID ) {
2005-09-27 01:55:36 +02:00
global $wpdb ;
2005-09-27 05:42:17 +02:00
$old_ID = ( int ) $old_ID ;
$new_ID = ( int ) $new_ID ;
2006-11-18 07:09:48 +01:00
return $wpdb -> query ( " UPDATE $wpdb->posts SET post_parent = $new_ID WHERE post_parent = $old_ID " );
2005-09-27 01:55:36 +02:00
}
2005-11-18 10:25:47 +01:00
// Replace hrefs of attachment anchors with up-to-date permalinks.
2006-11-18 07:09:48 +01:00
function fix_attachment_links ( $post_ID ) {
2005-11-18 10:25:47 +01:00
global $wp_rewrite ;
2006-11-18 07:09:48 +01:00
$post = & get_post ( $post_ID , ARRAY_A );
2005-11-18 10:25:47 +01:00
2007-02-15 02:03:06 +01:00
$search = " #<a[^>]+rel=('| \" )[^' \" ]*attachment[^>]*>#ie " ;
2005-11-18 10:25:47 +01:00
// See if we have any rel="attachment" links
2006-11-18 07:09:48 +01:00
if ( 0 == preg_match_all ( $search , $post [ 'post_content' ], $anchor_matches , PREG_PATTERN_ORDER ) )
2005-11-18 10:25:47 +01:00
return ;
$i = 0 ;
2007-02-15 02:03:06 +01:00
$search = " #[ \ s]+rel=( \" |')(.*?)wp-att-( \ d+) \\ 1#i " ;
2005-11-18 10:25:47 +01:00
foreach ( $anchor_matches [ 0 ] as $anchor ) {
2006-11-18 07:09:48 +01:00
if ( 0 == preg_match ( $search , $anchor , $id_matches ) )
2005-11-18 10:25:47 +01:00
continue ;
2006-10-19 02:37:10 +02:00
$id = $id_matches [ 3 ];
2005-11-30 23:44:00 +01:00
// While we have the attachment ID, let's adopt any orphans.
2006-11-18 07:09:48 +01:00
$attachment = & get_post ( $id , ARRAY_A );
if ( ! empty ( $attachment ) && ! is_object ( get_post ( $attachment [ 'post_parent' ] ) ) ) {
2006-03-02 03:47:36 +01:00
$attachment [ 'post_parent' ] = $post_ID ;
// Escape data pulled from DB.
2006-11-18 07:09:48 +01:00
$attachment = add_magic_quotes ( $attachment );
wp_update_post ( $attachment );
2005-11-30 23:44:00 +01:00
}
2005-11-18 10:25:47 +01:00
$post_search [ $i ] = $anchor ;
2006-11-18 07:09:48 +01:00
$post_replace [ $i ] = preg_replace ( " #href=( \" |')[^' \" ]* \\ 1#e " , " stripslashes( 'href= \\ 1' ).get_attachment_link( $id ).stripslashes( ' \\ 1' ) " , $anchor );
2005-11-18 10:25:47 +01:00
++ $i ;
}
2006-11-18 07:09:48 +01:00
$post [ 'post_content' ] = str_replace ( $post_search , $post_replace , $post [ 'post_content' ] );
2006-03-02 03:47:36 +01:00
// Escape data pulled from DB.
2006-11-18 07:09:48 +01:00
$post = add_magic_quotes ( $post );
2005-11-18 10:25:47 +01:00
2006-11-18 07:09:48 +01:00
return wp_update_post ( $post );
2005-11-18 10:25:47 +01: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
2006-02-11 10:56:02 +01:00
if ( 'page' == $_POST [ 'post_type' ] ) {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_page' , $post_ID ) )
wp_die ( __ ( 'You are not allowed to edit this page.' ));
2006-02-11 10:56:02 +01:00
} else {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
wp_die ( __ ( 'You are not allowed to edit this post.' ));
2006-02-11 10:56:02 +01:00
}
2005-06-19 03:33:38 +02:00
2007-01-18 04:32:54 +01:00
// Autosave shouldn't save too soon after a real save
if ( 'autosave' == $_POST [ 'action' ] ) {
$post =& get_post ( $post_ID );
$now = time ();
$then = strtotime ( $post -> post_date_gmt . ' +0000' );
// Keep autosave_interval in sync with autosave-js.php.
$delta = apply_filters ( 'autosave_interval' , 120 ) / 2 ;
if ( ( $now - $then ) < $delta )
return $post_ID ;
}
2005-06-19 03:33:38 +02:00
// Rename.
2005-06-26 21:55:12 +02:00
$_POST [ 'ID' ] = ( int ) $_POST [ 'post_ID' ];
2005-09-18 21:44:14 +02:00
$_POST [ 'post_content' ] = $_POST [ 'content' ];
$_POST [ 'post_excerpt' ] = $_POST [ 'excerpt' ];
2005-06-19 03:33:38 +02:00
$_POST [ 'post_parent' ] = $_POST [ 'parent_id' ];
$_POST [ 'to_ping' ] = $_POST [ 'trackback_url' ];
2006-11-18 07:09:48 +01:00
if ( ! empty ( $_POST [ 'post_author_override' ] ) ) {
2005-11-16 03:09:27 +01:00
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author_override' ];
2005-09-18 21:44:14 +02:00
} else
2006-11-18 07:09:48 +01:00
if ( ! empty ( $_POST [ 'post_author' ] ) ) {
2005-09-18 21:44:14 +02:00
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author' ];
} else {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'user_ID' ];
}
2005-06-19 03:33:38 +02:00
2006-11-18 07:09:48 +01:00
if ( $_POST [ 'post_author' ] != $_POST [ 'user_ID' ] ) {
2006-02-12 08:53:23 +01:00
if ( 'page' == $_POST [ 'post_type' ] ) {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_others_pages' ) )
2006-12-22 00:06:18 +01:00
wp_die ( __ ( 'You are not allowed to edit pages as this user.' ));
2006-02-11 10:56:02 +01:00
} else {
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_others_posts' ) )
2006-12-22 00:06:18 +01:00
wp_die ( __ ( 'You are not allowed to edit posts as this user.' ));
2006-02-12 08:53:23 +01:00
2006-02-11 10:56:02 +01:00
}
}
2005-06-19 03:33:38 +02:00
2005-07-17 23:08:47 +02:00
// What to do based on which button they pressed
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'saveasdraft' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'draft' ;
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'saveasprivate' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'private' ;
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'publish' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'publish' ;
2006-11-18 07:09:48 +01:00
if ( '' != $_POST [ 'advanced' ] )
2005-09-18 21:44:14 +02:00
$_POST [ 'post_status' ] = 'draft' ;
2006-02-11 10:56:02 +01:00
if ( 'page' == $_POST [ 'post_type' ] ) {
2006-11-18 07:09:48 +01:00
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'edit_published_pages' ))
2006-02-12 08:53:23 +01:00
$_POST [ 'post_status' ] = 'draft' ;
2006-02-11 10:56:02 +01:00
} else {
2006-11-18 07:09:48 +01:00
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'edit_published_posts' ))
2006-02-11 10:56:02 +01:00
$_POST [ 'post_status' ] = 'draft' ;
}
2005-12-05 05:04:23 +01:00
2006-11-18 07:09:48 +01:00
if ( ! isset ( $_POST [ 'comment_status' ] ))
2005-08-05 22:44:18 +02:00
$_POST [ 'comment_status' ] = 'closed' ;
2006-11-18 07:09:48 +01:00
if ( ! isset ( $_POST [ 'ping_status' ] ))
2005-08-05 22:44:18 +02:00
$_POST [ 'ping_status' ] = 'closed' ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01: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' ];
2006-11-18 07:09:48 +01:00
$jj = ( $jj > 31 ) ? 31 : $jj ;
$hh = ( $hh > 23 ) ? $hh - 24 : $hh ;
$mn = ( $mn > 59 ) ? $mn - 60 : $mn ;
$ss = ( $ss > 59 ) ? $ss - 60 : $ss ;
2005-06-19 03:33:38 +02:00
$_POST [ 'post_date' ] = " $aa - $mm - $jj $hh : $mn : $ss " ;
2006-11-18 07:09:48 +01:00
$_POST [ 'post_date_gmt' ] = get_gmt_from_date ( " $aa - $mm - $jj $hh : $mn : $ss " );
2005-09-18 21:44:14 +02:00
}
2005-06-19 03:33:38 +02:00
// Meta Stuff
2006-11-18 07:09:48 +01:00
if ( $_POST [ 'meta' ] ) {
foreach ( $_POST [ 'meta' ] as $key => $value )
update_meta ( $key , $value [ 'key' ], $value [ 'value' ] );
2005-11-22 01:36:36 +01:00
}
2006-02-12 08:53:23 +01:00
2006-11-18 07:09:48 +01:00
if ( $_POST [ 'deletemeta' ] ) {
foreach ( $_POST [ 'deletemeta' ] as $key => $value )
delete_meta ( $key );
2005-11-22 01:36:36 +01:00
}
2005-06-19 03:33:38 +02:00
2006-11-18 07:09:48 +01:00
add_meta ( $post_ID );
2005-09-18 21:44:14 +02:00
2007-02-15 02:03:06 +01:00
wp_update_post ( $_POST );
// Reunite any orphaned attachments with their parent
if ( ! $draft_ids = get_user_option ( 'autosave_draft_ids' ) )
$draft_ids = array ();
if ( $draft_temp_id = array_search ( $post_ID , $draft_ids ) )
relocate_children ( $draft_temp_id , $post_ID );
2005-11-22 01:36:36 +01:00
// Now that we have an ID we can fix any attachment anchor hrefs
2006-11-18 07:09:48 +01:00
fix_attachment_links ( $post_ID );
2005-11-22 01:36:36 +01:00
2005-09-08 22:38:30 +02:00
return $post_ID ;
2005-06-19 03:33:38 +02:00
}
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' ];
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( 'edit_post' , $comment_post_ID ))
wp_die ( __ ( 'You are not allowed to edit comments on this post, so you cannot edit this comment.' ));
2005-06-26 21:55:12 +02:00
$_POST [ 'comment_author' ] = $_POST [ 'newcomment_author' ];
2005-09-18 21:44:14 +02:00
$_POST [ 'comment_author_email' ] = $_POST [ 'newcomment_author_email' ];
2005-06-26 21:55:12 +02:00
$_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-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01: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' ];
2006-11-18 07:09:48 +01:00
$jj = ( $jj > 31 ) ? 31 : $jj ;
$hh = ( $hh > 23 ) ? $hh - 24 : $hh ;
$mn = ( $mn > 59 ) ? $mn - 60 : $mn ;
$ss = ( $ss > 59 ) ? $ss - 60 : $ss ;
2005-06-26 21:55:12 +02:00
$_POST [ 'comment_date' ] = " $aa - $mm - $jj $hh : $mn : $ss " ;
}
2006-11-18 07:09:48 +01:00
wp_update_comment ( $_POST );
2005-06-26 21:55:12 +02:00
}
2005-06-19 04:51:48 +02:00
// Get an existing post and format it for editing.
2006-11-18 07:09:48 +01:00
function get_post_to_edit ( $id ) {
2005-12-07 01:36:07 +01:00
2006-11-18 07:09:48 +01:00
$post = get_post ( $id );
2005-06-19 04:51:48 +02:00
2006-11-18 07:09:48 +01:00
$post -> post_content = format_to_edit ( $post -> post_content , user_can_richedit () );
$post -> post_content = apply_filters ( 'content_edit_pre' , $post -> post_content );
2005-06-19 04:51:48 +02:00
2006-11-18 07:09:48 +01:00
$post -> post_excerpt = format_to_edit ( $post -> post_excerpt );
$post -> post_excerpt = apply_filters ( 'excerpt_edit_pre' , $post -> post_excerpt );
2005-06-19 04:51:48 +02:00
2006-11-18 07:09:48 +01:00
$post -> post_title = format_to_edit ( $post -> post_title );
$post -> post_title = apply_filters ( 'title_edit_pre' , $post -> post_title );
2005-06-19 04:51:48 +02:00
2006-11-18 07:09:48 +01:00
$post -> post_password = format_to_edit ( $post -> post_password );
2006-08-25 00:33:16 +02:00
2006-11-18 07:09:48 +01:00
if ( $post -> post_type == 'page' )
$post -> page_template = get_post_meta ( $id , '_wp_page_template' , true );
2005-06-19 04:51:48 +02:00
return $post ;
}
// Default post information to use when populating the "Write Post" form.
function get_default_post_to_edit () {
2006-11-18 07:09:48 +01:00
if ( ! empty ( $_REQUEST [ 'post_title' ] ) )
$post_title = wp_specialchars ( stripslashes ( $_REQUEST [ 'post_title' ] ));
else if ( ! empty ( $_REQUEST [ 'popuptitle' ] ) ) {
$post_title = wp_specialchars ( stripslashes ( $_REQUEST [ 'popuptitle' ] ));
$post_title = funky_javascript_fix ( $post_title );
2005-11-17 04:26:24 +01:00
} else {
$post_title = '' ;
}
2006-11-18 07:09:48 +01:00
if ( ! empty ( $_REQUEST [ 'content' ] ) )
$post_content = wp_specialchars ( stripslashes ( $_REQUEST [ 'content' ] ));
else if ( ! empty ( $post_title ) ) {
$text = wp_specialchars ( stripslashes ( urldecode ( $_REQUEST [ 'text' ] ) ) );
$text = funky_javascript_fix ( $text );
2006-12-21 11:10:04 +01:00
$popupurl = attribute_escape ( $_REQUEST [ 'popupurl' ]);
2005-11-17 04:26:24 +01:00
$post_content = '<a href="' . $popupurl . '">' . $post_title . '</a>' . " \n $text " ;
}
2006-11-18 07:09:48 +01:00
if ( ! empty ( $_REQUEST [ 'excerpt' ] ) )
$post_excerpt = wp_specialchars ( stripslashes ( $_REQUEST [ 'excerpt' ] ));
2005-11-17 04:26:24 +01:00
else
$post_excerpt = '' ;
2005-06-19 04:51:48 +02:00
$post -> post_status = 'draft' ;
2006-11-18 07:09:48 +01:00
$post -> comment_status = get_option ( 'default_comment_status' );
$post -> ping_status = get_option ( 'default_ping_status' );
$post -> post_pingback = get_option ( 'default_pingback_flag' );
$post -> post_category = get_option ( 'default_category' );
$post -> post_content = apply_filters ( 'default_content' , $post_content );
$post -> post_title = apply_filters ( 'default_title' , $post_title );
$post -> post_excerpt = apply_filters ( 'default_excerpt' , $post_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 ;
}
2006-11-18 07:09:48 +01:00
function get_comment_to_edit ( $id ) {
$comment = get_comment ( $id );
2005-06-26 21:55:12 +02:00
2006-11-18 07:09:48 +01:00
$comment -> comment_content = format_to_edit ( $comment -> comment_content , user_can_richedit () );
$comment -> comment_content = apply_filters ( 'comment_edit_pre' , $comment -> comment_content );
2005-06-26 21:55:12 +02:00
2006-11-18 07:09:48 +01:00
$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 );
2005-06-26 21:55:12 +02:00
return $comment ;
}
2006-11-18 07:09:48 +01:00
function get_category_to_edit ( $id ) {
$category = get_category ( $id );
2005-07-03 21:26:51 +02:00
return $category ;
}
2006-04-02 02:31:26 +02:00
function wp_dropdown_roles ( $default = false ) {
global $wp_roles ;
$r = '' ;
2006-11-18 07:09:48 +01:00
foreach ( $wp_roles -> role_names as $role => $name )
2006-04-02 02:31:26 +02:00
if ( $default == $role ) // Make default first in list
$p = " \n \t <option selected='selected' value=' $role '> $name </option> " ;
else
$r .= " \n \t <option value=' $role '> $name </option> " ;
echo $p . $r ;
}
2006-11-18 07:09:48 +01:00
function get_user_to_edit ( $user_id ) {
$user = new WP_User ( $user_id );
2006-12-21 11:45:58 +01:00
$user -> user_login = attribute_escape ( $user -> user_login );
$user -> user_email = attribute_escape ( $user -> user_email );
$user -> user_url = attribute_escape ( $user -> user_url );
$user -> first_name = attribute_escape ( $user -> first_name );
$user -> last_name = attribute_escape ( $user -> last_name );
$user -> display_name = attribute_escape ( $user -> display_name );
$user -> nickname = attribute_escape ( $user -> nickname );
$user -> aim = attribute_escape ( $user -> aim );
$user -> yim = attribute_escape ( $user -> yim );
$user -> jabber = attribute_escape ( $user -> jabber );
$user -> description = wp_specialchars ( $user -> description );
2006-08-25 00:33:16 +02:00
return $user ;
}
2005-09-14 02:03:02 +02:00
// Creates a new user from the "Users" form using $_POST information.
function add_user () {
2006-04-02 02:31:26 +02:00
if ( func_num_args () ) { // The hackiest hack that ever did hack
global $current_user , $wp_roles ;
2006-11-18 07:09:48 +01:00
$user_id = func_get_arg ( 0 );
2006-07-27 00:18:36 +02:00
2006-11-18 07:09:48 +01:00
if ( isset ( $_POST [ 'role' ] ) ) {
if ( $user_id != $current_user -> id || $wp_roles -> role_objects [ $_POST [ 'role' ]] -> has_cap ( 'edit_users' ) ) {
$user = new WP_User ( $user_id );
$user -> set_role ( $_POST [ 'role' ] );
2006-04-02 02:31:26 +02:00
}
}
} else {
2006-11-18 07:09:48 +01:00
add_action ( 'user_register' , 'add_user' ); // See above
2006-04-02 02:31:26 +02:00
return edit_user ();
}
2005-09-14 02:03:02 +02:00
}
2006-11-18 07:09:48 +01:00
function edit_user ( $user_id = 0 ) {
2006-01-25 04:09:16 +01:00
global $current_user , $wp_roles , $wpdb ;
2006-11-18 07:09:48 +01:00
if ( $user_id != 0 ) {
2005-09-14 02:03:02 +02:00
$update = true ;
$user -> ID = $user_id ;
2006-11-18 07:09:48 +01:00
$userdata = get_userdata ( $user_id );
$user -> user_login = $wpdb -> escape ( $userdata -> user_login );
2005-09-14 02:03:02 +02:00
} else {
$update = false ;
$user = '' ;
}
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( isset ( $_POST [ 'user_login' ] ))
$user -> user_login = wp_specialchars ( trim ( $_POST [ 'user_login' ] ));
2005-09-14 02:03:02 +02:00
$pass1 = $pass2 = '' ;
2006-11-18 07:09:48 +01:00
if ( isset ( $_POST [ 'pass1' ] ))
2005-09-14 02:03:02 +02:00
$pass1 = $_POST [ 'pass1' ];
2006-11-18 07:09:48 +01:00
if ( isset ( $_POST [ 'pass2' ] ))
2005-09-14 02:03:02 +02:00
$pass2 = $_POST [ 'pass2' ];
2006-11-18 07:09:48 +01:00
if ( isset ( $_POST [ 'role' ] ) && current_user_can ( 'edit_users' ) ) {
if ( $user_id != $current_user -> id || $wp_roles -> role_objects [ $_POST [ 'role' ]] -> has_cap ( 'edit_users' ))
2005-11-06 04:58:52 +01:00
$user -> role = $_POST [ 'role' ];
}
2006-11-18 07:09:48 +01:00
if ( isset ( $_POST [ 'email' ] ))
$user -> user_email = wp_specialchars ( trim ( $_POST [ 'email' ] ));
if ( isset ( $_POST [ 'url' ] ) ) {
$user -> user_url = wp_specialchars ( trim ( $_POST [ 'url' ] ));
2006-11-30 02:50:48 +01:00
$user -> user_url = preg_match ( '/^(https?|ftps?|mailto|news|irc|gopher|nntp|feed|telnet):/is' , $user -> user_url ) ? $user -> user_url : 'http://' . $user -> user_url ;
2006-11-18 07:09:48 +01:00
}
if ( isset ( $_POST [ 'first_name' ] ))
$user -> first_name = wp_specialchars ( trim ( $_POST [ 'first_name' ] ));
if ( isset ( $_POST [ 'last_name' ] ))
$user -> last_name = wp_specialchars ( trim ( $_POST [ 'last_name' ] ));
if ( isset ( $_POST [ 'nickname' ] ))
$user -> nickname = wp_specialchars ( trim ( $_POST [ 'nickname' ] ));
if ( isset ( $_POST [ 'display_name' ] ))
$user -> display_name = wp_specialchars ( trim ( $_POST [ 'display_name' ] ));
if ( isset ( $_POST [ 'description' ] ))
$user -> description = trim ( $_POST [ 'description' ] );
if ( isset ( $_POST [ 'jabber' ] ))
$user -> jabber = wp_specialchars ( trim ( $_POST [ 'jabber' ] ));
if ( isset ( $_POST [ 'aim' ] ))
$user -> aim = wp_specialchars ( trim ( $_POST [ 'aim' ] ));
if ( isset ( $_POST [ 'yim' ] ))
$user -> yim = wp_specialchars ( trim ( $_POST [ 'yim' ] ));
2006-12-20 00:19:12 +01:00
if ( ! $update )
$user -> rich_editing = 'true' ; // Default to true for new users.
else if ( isset ( $_POST [ 'rich_editing' ] ) )
$user -> rich_editing = $_POST [ 'rich_editing' ];
else
$user -> rich_editing = 'false' ;
2005-09-14 02:03:02 +02:00
2006-04-02 02:31:26 +02:00
$errors = new WP_Error ();
2005-09-18 21:44:14 +02:00
2005-09-14 02:03:02 +02:00
/* checking that username has been typed */
2006-11-18 07:09:48 +01:00
if ( $user -> user_login == '' )
$errors -> add ( 'user_login' , __ ( '<strong>ERROR</strong>: Please enter a username.' ));
2005-09-14 02:03:02 +02:00
/* checking the password has been typed twice */
2006-11-18 07:09:48 +01:00
do_action_ref_array ( 'check_passwords' , array ( $user -> user_login , & $pass1 , & $pass2 ));
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( ! $update ) {
if ( $pass1 == '' || $pass2 == '' )
$errors -> add ( 'pass' , __ ( '<strong>ERROR</strong>: Please enter your password twice.' ));
2005-09-14 02:03:02 +02:00
} else {
2006-11-18 07:09:48 +01:00
if (( empty ( $pass1 ) && ! empty ( $pass2 ) ) || ( empty ( $pass2 ) && ! empty ( $pass1 ) ) )
$errors -> add ( 'pass' , __ ( " <strong>ERROR</strong>: you typed your new password only once. " ));
2005-09-14 02:03:02 +02:00
}
2005-09-18 21:44:14 +02:00
2005-11-14 10:59:47 +01:00
/* Check for "\" in password */
if ( strpos ( " " . $pass1 , " \\ " ) )
2006-11-18 07:09:48 +01:00
$errors -> add ( 'pass' , __ ( '<strong>ERROR</strong>: Passwords may not contain the character "\\".' ));
2005-11-14 10:59:47 +01:00
2005-09-14 02:03:02 +02:00
/* checking the password has been typed twice the same */
2006-11-18 07:09:48 +01:00
if ( $pass1 != $pass2 )
$errors -> add ( 'pass' , __ ( '<strong>ERROR</strong>: Please type the same password in the two password fields.' ));
2005-09-14 02:03:02 +02:00
2006-11-18 07:09:48 +01:00
if ( ! empty ( $pass1 ))
2005-09-14 02:03:02 +02:00
$user -> user_pass = $pass1 ;
2005-09-18 21:44:14 +02:00
2007-01-07 08:52:57 +01:00
if ( ! $update && ! validate_username ( $user -> user_login ) )
2006-11-18 07:09:48 +01:00
$errors -> add ( 'user_login' , __ ( '<strong>ERROR</strong>: This username is invalid. Please enter a valid username.' ));
2006-01-25 04:09:16 +01:00
2006-11-18 07:09:48 +01:00
if ( ! $update && username_exists ( $user -> user_login ))
$errors -> add ( 'user_login' , __ ( '<strong>ERROR</strong>: This username is already registered, please choose another one.' ));
2005-09-14 02:03:02 +02:00
/* checking e-mail address */
2006-11-18 07:09:48 +01:00
if ( empty ( $user -> user_email ) ) {
$errors -> add ( 'user_email' , __ ( " <strong>ERROR</strong>: please type an e-mail address " ));
2005-09-18 21:44:14 +02:00
} else
2006-11-18 07:09:48 +01:00
if ( ! is_email ( $user -> user_email ) ) {
$errors -> add ( 'user_email' , __ ( " <strong>ERROR</strong>: the email address isn't correct " ));
2005-09-18 21:44:14 +02:00
}
2005-09-14 02:03:02 +02:00
2006-04-02 02:31:26 +02:00
if ( $errors -> get_error_codes () )
2005-09-14 02:03:02 +02:00
return $errors ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( $update ) {
$user_id = wp_update_user ( get_object_vars ( $user ));
2005-09-14 02:03:02 +02:00
} else {
2006-11-18 07:09:48 +01:00
$user_id = wp_insert_user ( get_object_vars ( $user ));
wp_new_user_notification ( $user_id );
2005-09-14 02:03:02 +02:00
}
2006-04-02 02:31:26 +02:00
return $user_id ;
2005-09-14 02:03:02 +02:00
}
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
function get_link_to_edit ( $link_id ) {
$link = get_link ( $link_id );
2006-02-12 08:53:23 +01:00
2006-12-21 11:45:58 +01:00
$link -> link_url = attribute_escape ( $link -> link_url );
$link -> link_name = attribute_escape ( $link -> link_name );
$link -> link_image = attribute_escape ( $link -> link_image );
$link -> link_description = attribute_escape ( $link -> link_description );
$link -> link_rss = attribute_escape ( $link -> link_rss );
$link -> link_rel = attribute_escape ( $link -> link_rel );
$link -> link_notes = wp_specialchars ( $link -> link_notes );
$link -> post_category = $link -> link_category ;
2006-02-12 08:53:23 +01:00
2005-09-18 21:44:14 +02:00
return $link ;
}
2005-09-19 02:47:58 +02:00
function get_default_link_to_edit () {
2006-11-18 07:09:48 +01:00
if ( isset ( $_GET [ 'linkurl' ] ) )
2006-12-21 11:10:04 +01:00
$link -> link_url = attribute_escape ( $_GET [ 'linkurl' ]);
2005-09-19 02:47:58 +02:00
else
$link -> link_url = '' ;
2006-02-12 08:53:23 +01:00
2006-11-18 07:09:48 +01:00
if ( isset ( $_GET [ 'name' ] ) )
2006-12-21 11:10:04 +01:00
$link -> link_name = attribute_escape ( $_GET [ 'name' ]);
2005-09-19 02:47:58 +02:00
else
$link -> link_name = '' ;
2006-02-12 08:53:23 +01:00
2006-02-27 05:57:30 +01:00
$link -> link_visible = 'Y' ;
2005-09-19 02:47:58 +02:00
return $link ;
}
2005-09-18 21:44:14 +02:00
function add_link () {
2006-02-12 08:53:23 +01:00
return edit_link ();
2005-09-18 21:44:14 +02:00
}
2006-11-18 07:09:48 +01:00
function edit_link ( $link_id = '' ) {
if ( ! current_user_can ( 'manage_links' ))
2006-12-27 01:51:00 +01:00
wp_die ( __ ( 'Cheatin’ uh?' ));
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
$_POST [ 'link_url' ] = wp_specialchars ( $_POST [ 'link_url' ] );
2006-11-30 02:50:48 +01:00
$_POST [ 'link_url' ] = preg_match ( '/^(https?|ftps?|mailto|news|irc|gopher|nntp|feed|telnet):/is' , $_POST [ 'link_url' ]) ? $_POST [ 'link_url' ] : 'http://' . $_POST [ 'link_url' ];
2006-11-18 07:09:48 +01:00
$_POST [ 'link_name' ] = wp_specialchars ( $_POST [ 'link_name' ] );
$_POST [ 'link_image' ] = wp_specialchars ( $_POST [ 'link_image' ] );
$_POST [ 'link_rss' ] = wp_specialchars ( $_POST [ 'link_rss' ] );
2006-02-27 05:57:30 +01:00
$_POST [ 'link_category' ] = $_POST [ 'post_category' ];
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( ! empty ( $link_id ) ) {
2005-09-18 21:44:14 +02:00
$_POST [ 'link_id' ] = $link_id ;
2006-11-18 07:09:48 +01:00
return wp_update_link ( $_POST );
2005-09-18 21:44:14 +02:00
} else {
2006-11-18 07:09:48 +01:00
return wp_insert_link ( $_POST );
2005-09-18 21:44:14 +02:00
}
}
2006-11-18 07:09:48 +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 ) . '...' ;
2004-02-17 09:35:04 +01:00
return $short_url ;
}
2006-11-18 07:09:48 +01:00
function selected ( $selected , $current ) {
if ( $selected == $current )
2005-09-18 21:44:14 +02:00
echo ' selected="selected"' ;
2004-02-13 10:59:47 +01:00
}
2006-11-18 07:09:48 +01:00
function checked ( $checked , $current ) {
if ( $checked == $current )
2005-09-18 21:44:14 +02:00
echo ' checked="checked"' ;
2004-02-13 10:59:47 +01:00
}
2006-11-18 07:09:48 +01:00
function return_categories_list ( $parent = 0 ) {
2005-07-23 08:22:48 +02:00
global $wpdb ;
2007-01-10 01:22:17 +01:00
return $wpdb -> get_col ( " SELECT cat_ID FROM $wpdb->categories WHERE category_parent = $parent AND ( link_count = 0 OR category_count != 0 OR ( link_count = 0 AND category_count = 0 ) ) ORDER BY category_count DESC " );
2005-11-06 07:48:41 +01:00
}
2006-11-18 07:09:48 +01:00
function sort_cats ( $cat1 , $cat2 ) {
2006-11-30 01:22:18 +01:00
if ( $cat1 [ 'checked' ] || $cat2 [ 'checked' ] )
return ( $cat1 [ 'checked' ] && ! $cat2 [ 'checked' ] ) ? - 1 : 1 ;
else
return strcasecmp ( $cat1 [ 'cat_name' ], $cat2 [ 'cat_name' ] );
2004-06-16 18:40:40 +02:00
}
2006-11-18 07:09:48 +01:00
function get_nested_categories ( $default = 0 , $parent = 0 ) {
2006-02-27 05:57:30 +01:00
global $post_ID , $link_id , $mode , $wpdb ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( $post_ID ) {
$checked_categories = $wpdb -> get_col ( "
2005-09-18 21:44:14 +02:00
SELECT category_id
FROM $wpdb -> categories , $wpdb -> post2cat
WHERE $wpdb -> post2cat . category_id = cat_ID AND $wpdb -> post2cat . post_id = '$post_ID'
2006-11-18 07:09:48 +01:00
" );
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( count ( $checked_categories ) == 0 ) {
2005-09-18 21:44:14 +02:00
// No selected categories, strange
$checked_categories [] = $default ;
}
2006-11-18 07:09:48 +01:00
} else if ( $link_id ) {
$checked_categories = $wpdb -> get_col ( "
2006-02-27 05:57:30 +01:00
SELECT category_id
FROM $wpdb -> categories , $wpdb -> link2cat
WHERE $wpdb -> link2cat . category_id = cat_ID AND $wpdb -> link2cat . link_id = '$link_id'
2006-11-18 07:09:48 +01:00
" );
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( count ( $checked_categories ) == 0 ) {
2006-02-27 05:57:30 +01:00
// No selected categories, strange
$checked_categories [] = $default ;
2007-02-27 16:24:54 +01:00
}
2005-09-18 21:44:14 +02:00
} else {
$checked_categories [] = $default ;
}
2006-11-18 07:09:48 +01:00
$cats = return_categories_list ( $parent );
2005-09-18 21:44:14 +02:00
$result = array ();
2006-11-18 07:09:48 +01:00
if ( is_array ( $cats ) ) {
foreach ( $cats as $cat ) {
$result [ $cat ][ 'children' ] = get_nested_categories ( $default , $cat );
2005-08-03 02:21:53 +02:00
$result [ $cat ][ 'cat_ID' ] = $cat ;
2006-11-18 07:09:48 +01:00
$result [ $cat ][ 'checked' ] = in_array ( $cat , $checked_categories );
$result [ $cat ][ 'cat_name' ] = get_the_category_by_ID ( $cat );
2005-08-03 02:21:53 +02:00
}
}
2006-02-12 08:53:23 +01:00
2006-11-18 07:09:48 +01:00
usort ( $result , 'sort_cats' );
2004-02-09 09:55:29 +01:00
2005-08-03 02:21:53 +02:00
return $result ;
2004-02-09 09:55:29 +01:00
}
2006-11-18 07:09:48 +01:00
function write_nested_categories ( $categories ) {
foreach ( $categories as $category ) {
2006-11-22 07:04:09 +01:00
echo '<li id="category-' , $category [ 'cat_ID' ], '"><label for="in-category-' , $category [ 'cat_ID' ], '" class="selectit"><input value="' , $category [ 'cat_ID' ], '" type="checkbox" name="post_category[]" id="in-category-' , $category [ 'cat_ID' ], '"' , ( $category [ 'checked' ] ? ' checked="checked"' : " " ), '/> ' , wp_specialchars ( $category [ 'cat_name' ] ), " </label></li> " ;
2004-02-09 09:55:29 +01:00
2006-03-29 03:51:55 +02:00
if ( $category [ 'children' ] ) {
echo " <ul> \n " ;
2006-11-18 07:09:48 +01:00
write_nested_categories ( $category [ 'children' ] );
2006-03-29 03:51:55 +02:00
echo " </ul> \n " ;
2005-09-18 21:44:14 +02:00
}
}
2004-02-09 09:55:29 +01:00
}
2006-11-18 07:09:48 +01:00
function dropdown_categories ( $default = 0 ) {
write_nested_categories ( get_nested_categories ( $default ) );
2005-09-18 21:44:14 +02:00
}
2004-01-27 10:33:19 +01:00
2006-11-18 07:09:48 +01:00
function return_link_categories_list ( $parent = 0 ) {
2006-07-06 06:27:45 +02:00
global $wpdb ;
2007-01-10 01:22:17 +01:00
return $wpdb -> get_col ( " SELECT cat_ID FROM $wpdb->categories WHERE category_parent = $parent AND ( category_count = 0 OR link_count != 0 OR ( link_count = 0 AND category_count = 0 ) ) ORDER BY link_count DESC " );
2006-07-06 06:27:45 +02:00
}
function get_nested_link_categories ( $default = 0 , $parent = 0 ) {
global $post_ID , $link_id , $mode , $wpdb ;
2006-11-18 07:09:48 +01:00
if ( $link_id ) {
$checked_categories = $wpdb -> get_col ( "
2006-07-06 06:27:45 +02:00
SELECT category_id
FROM $wpdb -> categories , $wpdb -> link2cat
WHERE $wpdb -> link2cat . category_id = cat_ID AND $wpdb -> link2cat . link_id = '$link_id'
2006-11-18 07:09:48 +01:00
" );
2006-07-06 06:27:45 +02:00
2006-11-18 07:09:48 +01:00
if ( count ( $checked_categories ) == 0 ) {
2006-07-06 06:27:45 +02:00
// No selected categories, strange
$checked_categories [] = $default ;
2007-02-27 16:24:54 +01:00
}
2006-07-06 06:27:45 +02:00
} else {
$checked_categories [] = $default ;
}
2006-11-18 07:09:48 +01:00
$cats = return_link_categories_list ( $parent );
2006-07-06 06:27:45 +02:00
$result = array ();
2006-11-18 07:09:48 +01:00
if ( is_array ( $cats ) ) {
foreach ( $cats as $cat ) {
$result [ $cat ][ 'children' ] = get_nested_link_categories ( $default , $cat );
2006-07-06 06:27:45 +02:00
$result [ $cat ][ 'cat_ID' ] = $cat ;
2006-11-18 07:09:48 +01:00
$result [ $cat ][ 'checked' ] = in_array ( $cat , $checked_categories );
$result [ $cat ][ 'cat_name' ] = get_the_category_by_ID ( $cat );
2006-07-06 06:27:45 +02:00
}
}
2006-11-18 07:09:48 +01:00
usort ( $result , 'sort_cats' );
2006-07-06 06:27:45 +02:00
return $result ;
}
2006-11-18 07:09:48 +01:00
function dropdown_link_categories ( $default = 0 ) {
write_nested_categories ( get_nested_link_categories ( $default ) );
2006-07-06 06:27:45 +02:00
}
2004-01-27 10:33:19 +01:00
// Dandy new recursive multiple category stuff.
2006-11-18 07:09:48 +01:00
function cat_rows ( $parent = 0 , $level = 0 , $categories = 0 ) {
if ( ! $categories )
$categories = get_categories ( 'hide_empty=0' );
2004-11-18 20:51:31 +01:00
2006-11-18 07:09:48 +01:00
if ( $categories ) {
2006-12-04 01:48:03 +01:00
ob_start ();
2006-11-18 07:09:48 +01:00
foreach ( $categories as $category ) {
if ( $category -> category_parent == $parent ) {
2006-07-25 08:36:10 +02:00
echo " \t " . _cat_row ( $category , $level );
2006-11-18 07:09:48 +01:00
cat_rows ( $category -> cat_ID , $level + 1 , $categories );
2005-01-02 00:05:07 +01:00
}
}
2006-12-04 01:48:03 +01:00
$output = ob_get_contents ();
ob_end_clean ();
2007-02-27 16:24:54 +01:00
2006-12-04 01:48:03 +01:00
$output = apply_filters ( 'cat_rows' , $output );
echo $output ;
2005-01-02 00:05:07 +01:00
} else {
return false ;
}
}
2006-07-25 08:36:10 +02:00
function _cat_row ( $category , $level , $name_override = false ) {
global $class ;
2006-11-18 07:09:48 +01:00
$pad = str_repeat ( '— ' , $level );
if ( current_user_can ( 'manage_categories' ) ) {
$edit = " <a href='categories.php?action=edit&cat_ID= $category->cat_ID ' class='edit'> " . __ ( 'Edit' ) . " </a></td> " ;
$default_cat_id = get_option ( 'default_category' );
$default_link_cat_id = get_option ( 'default_link_category' );
2006-07-25 08:36:10 +02:00
2006-11-18 07:09:48 +01:00
if ( ( $category -> cat_ID != $default_cat_id ) && ( $category -> cat_ID != $default_link_cat_id ) )
2007-01-08 04:02:33 +01:00
$edit .= " <td><a href=' " . wp_nonce_url ( " categories.php?action=delete&cat_ID= $category->cat_ID " , 'delete-category_' . $category -> cat_ID ) . " ' onclick= \" return deleteSomething( 'cat', $category->cat_ID , ' " . js_escape ( sprintf ( __ ( " You are about to delete the category '%s'. \n All of its posts will go into the default category of '%s' \n All of its bookmarks will go into the default category of '%s'. \n 'OK' to delete, 'Cancel' to stop. " ), $category -> cat_name , get_catname ( $default_cat_id ), get_catname ( $default_link_cat_id ) )) . " ' ); \" class='delete'> " . __ ( 'Delete' ) . " </a> " ;
2006-07-25 08:36:10 +02:00
else
2006-11-18 07:09:48 +01:00
$edit .= " <td style='text-align:center'> " . __ ( " Default " );
2006-07-25 08:36:10 +02:00
} else
$edit = '' ;
2006-11-18 07:09:48 +01:00
$class = ( ( defined ( 'DOING_AJAX' ) && DOING_AJAX ) || " class='alternate' " == $class ) ? '' : " class='alternate' " ;
2006-07-25 08:36:10 +02:00
$category -> category_count = number_format ( $category -> category_count );
$category -> link_count = number_format ( $category -> link_count );
2006-12-22 00:40:16 +01:00
$posts_count = ( $category -> category_count > 0 ) ? " <a href='edit.php?cat= $category->cat_ID '> $category->category_count </a> " : $category -> category_count ;
2006-07-25 08:36:10 +02:00
return " <tr id='cat- $category->cat_ID ' $class >
2006-09-27 02:51:17 +02:00
< th scope = 'row' style = 'text-align: center' > $category -> cat_ID </ th >
2006-07-25 08:36:10 +02:00
< td > " . ( $name_override ? $name_override : $pad . ' ' . $category->cat_name ) . " </ td >
< td > $category -> category_description </ td >
2006-12-22 00:40:16 +01:00
< td align = 'center' > $posts_count </ td >
2006-07-25 08:36:10 +02:00
< td align = 'center' > $category -> link_count </ td >
< td > $edit </ td > \n\t </ tr > \n " ;
}
2006-11-18 07:09:48 +01:00
function page_rows ( $parent = 0 , $level = 0 , $pages = 0 , $hierarchy = true ) {
2005-07-15 04:16:45 +02:00
global $wpdb , $class , $post ;
2006-02-21 09:39:58 +01:00
2006-11-18 07:09:48 +01:00
if ( ! $pages )
$pages = get_pages ( 'sort_column=menu_order' );
2005-01-02 00:05:07 +01:00
2006-11-18 07:09:48 +01:00
if ( ! $pages )
2006-02-21 09:39:58 +01:00
return false ;
2006-11-18 07:09:48 +01:00
foreach ( $pages as $post ) {
setup_postdata ( $post );
2006-02-21 09:39:58 +01:00
if ( $hierarchy && ( $post -> post_parent != $parent ) )
continue ;
2006-11-18 07:09:48 +01:00
$post -> post_title = wp_specialchars ( $post -> post_title );
$pad = str_repeat ( '— ' , $level );
2006-02-21 09:39:58 +01:00
$id = $post -> ID ;
2006-11-18 07:09:48 +01:00
$class = ( 'alternate' == $class ) ? '' : 'alternate' ;
2005-01-02 00:05:07 +01:00
?>
2005-08-31 04:39:17 +02:00
< tr id = 'page-<?php echo $id; ?>' class = '<?php echo $class; ?>' >
2006-09-27 02:51:17 +02:00
< th scope = " row " style = " text-align: center " >< ? php echo $post -> ID ; ?> </th>
2005-01-02 00:05:07 +01:00
< td >
2006-06-14 22:47:12 +02:00
< ? php echo $pad ; ?> <?php the_title() ?>
2005-01-02 00:05:07 +01:00
</ td >
< td >< ? php the_author () ?> </td>
2007-01-25 03:08:54 +01:00
< td >< ? php if ( '0000-00-00 00:00:00' == $post -> post_modified ) _e ( 'Unpublished' ); else echo mysql2date ( __ ( 'Y-m-d g:i a' ), $post -> post_modified ); ?> </td>
2006-11-18 07:09:48 +01:00
< td >< a href = " <?php the_permalink(); ?> " rel = " permalink " class = " edit " >< ? php _e ( 'View' ); ?> </a></td>
< td >< ? php if ( current_user_can ( 'edit_page' , $id ) ) { echo " <a href='page.php?action=edit&post= $id ' class='edit'> " . __ ( 'Edit' ) . " </a> " ; } ?> </td>
2007-01-08 04:02:33 +01:00
< td >< ? php if ( current_user_can ( 'delete_page' , $id ) ) { echo " <a href=' " . wp_nonce_url ( " page.php?action=delete&post= $id " , 'delete-page_' . $id ) . " ' class='delete' onclick= \" return deleteSomething( 'page', " . $id . " , ' " . js_escape ( sprintf ( __ ( " You are about to delete the '%s' page. \n 'OK' to delete, 'Cancel' to stop. " ), get_the_title () ) ) . " ' ); \" > " . __ ( 'Delete' ) . " </a> " ; } ?> </td>
2005-01-02 00:05:07 +01:00
</ tr >
< ? php
2006-11-18 07:09:48 +01:00
if ( $hierarchy ) page_rows ( $id , $level + 1 , $pages );
2004-01-27 10:33:19 +01:00
}
}
2006-04-02 02:31:26 +02:00
function user_row ( $user_object , $style = '' ) {
2006-11-18 07:09:48 +01:00
if ( ! ( is_object ( $user_object ) && is_a ( $user_object , 'WP_User' ) ) )
2006-04-02 02:31:26 +02:00
$user_object = new WP_User ( ( int ) $user_object );
$email = $user_object -> user_email ;
$url = $user_object -> user_url ;
2006-11-18 07:09:48 +01:00
$short_url = str_replace ( 'http://' , '' , $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 ) . '...' ;
$numposts = get_usernumposts ( $user_object -> ID );
2006-04-02 02:31:26 +02:00
$r = " <tr id='user- $user_object->ID ' $style >
< td >< input type = 'checkbox' name = 'users[]' id = 'user_{$user_object->ID}' value = '{$user_object->ID}' /> < label for = 'user_{$user_object->ID}' > { $user_object -> ID } </ label ></ td >
< td >< label for = 'user_{$user_object->ID}' >< strong > $user_object -> user_login </ strong ></ label ></ td >
< td >< label for = 'user_{$user_object->ID}' > $user_object -> first_name $user_object -> last_name </ label ></ td >
2006-11-18 07:09:48 +01:00
< td >< a href = 'mailto:$email' title = '" . sprintf( __(' e - mail : % s ' ), $email ) . "' > $email </ a ></ td >
2006-04-02 02:31:26 +02:00
< td >< a href = '$url' title = 'website: $url' > $short_url </ a ></ td > " ;
2006-06-08 20:36:05 +02:00
$r .= " \n \t \t <td align='center'> " ;
2006-11-18 07:09:48 +01:00
if ( $numposts > 0 ) {
$r .= " <a href='edit.php?author= $user_object->ID ' title=' " . __ ( 'View posts by this author' ) . " ' class='edit'> " ;
2006-12-22 00:06:18 +01:00
$r .= sprintf ( __ngettext ( 'View %s post' , 'View %s posts' , $numposts ), $numposts );
2006-12-02 00:00:04 +01:00
$r .= '</a>' ;
2006-06-08 20:36:05 +02:00
}
$r .= " </td> \n \t \t <td> " ;
2006-12-02 00:00:04 +01:00
if ( current_user_can ( 'edit_user' , $user_object -> ID ) ) {
2006-12-21 11:10:04 +01:00
$edit_link = attribute_escape ( add_query_arg ( 'wp_http_referer' , urlencode ( stripslashes ( $_SERVER [ 'REQUEST_URI' ] ) ), " user-edit.php?user_id= $user_object->ID " ));
2006-11-18 07:09:48 +01:00
$r .= " <a href=' $edit_link ' class='edit'> " . __ ( 'Edit' ) . " </a> " ;
2006-12-02 00:00:04 +01:00
}
2006-04-02 02:31:26 +02:00
$r .= " </td> \n \t </tr> " ;
return $r ;
}
2006-11-18 07:09:48 +01:00
function wp_dropdown_cats ( $currentcat = 0 , $currentparent = 0 , $parent = 0 , $level = 0 , $categories = 0 ) {
2006-06-06 07:36:28 +02:00
global $wpdb ;
2006-11-18 07:09:48 +01:00
if ( ! $categories )
$categories = get_categories ( 'hide_empty=0' );
if ( $categories ) {
foreach ( $categories as $category ) {
if ( $currentcat != $category -> cat_ID && $parent == $category -> category_parent ) {
$pad = str_repeat ( '– ' , $level );
$category -> cat_name = wp_specialchars ( $category -> cat_name );
2005-09-18 21:44:14 +02:00
echo " \n \t <option value=' $category->cat_ID ' " ;
2006-11-18 07:09:48 +01:00
if ( $currentparent == $category -> cat_ID )
2005-09-18 21:44:14 +02:00
echo " selected='selected' " ;
echo " > $pad $category->cat_name </option> " ;
2006-11-18 07:09:48 +01:00
wp_dropdown_cats ( $currentcat , $currentparent , $category -> cat_ID , $level + 1 , $categories );
2005-09-18 21:44:14 +02:00
}
}
2004-01-27 10:33:19 +01:00
} else {
return false ;
}
}
2004-03-23 19:02:05 +01:00
// Some postmeta stuff
2006-11-18 07:09:48 +01:00
function has_meta ( $postid ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-03-23 19:02:05 +01:00
2006-11-18 07:09:48 +01:00
return $wpdb -> get_results ( "
2005-09-18 21:44:14 +02:00
SELECT meta_key , meta_value , meta_id , post_id
FROM $wpdb -> postmeta
WHERE post_id = '$postid'
2006-11-18 07:09:48 +01:00
ORDER BY meta_key , meta_id " , ARRAY_A );
2004-03-23 19:02:05 +01:00
}
2006-11-18 07:09:48 +01:00
function list_meta ( $meta ) {
2005-09-18 21:44:14 +02:00
global $post_ID ;
2004-03-23 19:02:05 +01:00
// Exit if no meta
2006-11-18 07:09:48 +01:00
if ( ! $meta ) {
2006-09-07 19:28:29 +02:00
echo '<tbody id="the-list"><tr style="display: none;"><td> </td></tr></tbody>' ; //TBODY needed for list-manipulation JS
2005-09-18 21:44:14 +02:00
return ;
2006-03-29 03:51:55 +02:00
}
2004-12-09 05:12:20 +01:00
$count = 0 ;
2004-04-28 04:23:46 +02:00
?>
2006-03-29 03:51:55 +02:00
< thead >
2004-04-28 04:23:46 +02:00
< tr >
2006-11-18 07:09:48 +01:00
< th >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
< th colspan = '2' >< ? php _e ( 'Action' ) ?> </th>
2004-04-28 04:23:46 +02:00
</ tr >
2006-03-29 03:51:55 +02:00
</ thead >
2004-04-28 04:23:46 +02:00
< ? php
2006-03-29 03:51:55 +02:00
$r = " \n \t <tbody id='the-list'> " ;
2006-11-18 07:09:48 +01:00
foreach ( $meta as $entry ) {
2005-09-18 21:44:14 +02:00
++ $count ;
2006-11-18 07:09:48 +01:00
if ( $count % 2 )
2005-09-18 21:44:14 +02:00
$style = 'alternate' ;
else
$style = '' ;
2006-11-18 07:09:48 +01:00
if ( '_' == $entry [ 'meta_key' ] { 0 } )
2005-09-18 21:44:14 +02:00
$style .= ' hidden' ;
2006-10-13 01:54:36 +02:00
2006-11-18 07:09:48 +01:00
if ( is_serialized ( $entry [ 'meta_value' ] ) ) {
if ( is_serialized_string ( $entry [ 'meta_value' ] ) ) {
2006-10-13 01:54:36 +02:00
// this is a serialized string, so we should display it
2006-11-18 07:09:48 +01:00
$entry [ 'meta_value' ] = maybe_unserialize ( $entry [ 'meta_value' ] );
2006-10-13 01:54:36 +02:00
} else {
// this is a serialized array/object so we should NOT display it
-- $count ;
continue ;
}
}
2006-11-18 07:09:48 +01:00
$key_js = js_escape ( $entry [ 'meta_key' ] );
2006-12-21 11:45:58 +01:00
$entry [ 'meta_key' ] = attribute_escape ( $entry [ 'meta_key' ]);
$entry [ 'meta_value' ] = attribute_escape ( $entry [ 'meta_value' ]);
2006-03-29 03:51:55 +02:00
$r .= " \n \t <tr id='meta- { $entry [ 'meta_id' ] } ' class=' $style '> " ;
$r .= " \n \t \t <td valign='top'><input name='meta[ { $entry [ 'meta_id' ] } ][key]' tabindex='6' type='text' size='20' value=' { $entry [ 'meta_key' ] } ' /></td> " ;
$r .= " \n \t \t <td><textarea name='meta[ { $entry [ 'meta_id' ] } ][value]' tabindex='6' rows='2' cols='30'> { $entry [ 'meta_value' ] } </textarea></td> " ;
2007-01-08 04:02:33 +01:00
$r .= " \n \t \t <td align='center'><input name='updatemeta' type='submit' class='updatemeta' tabindex='6' value=' " . attribute_escape ( __ ( 'Update' )) . " ' /><br /> " ;
2006-03-29 03:51:55 +02:00
$r .= " \n \t \t <input name='deletemeta[ { $entry [ 'meta_id' ] } ]' type='submit' onclick= \" return deleteSomething( 'meta', { $entry [ 'meta_id' ] } , ' " ;
2007-01-08 04:02:33 +01:00
$r .= js_escape ( sprintf ( __ ( " You are about to delete the '%s' custom field on this post. \n 'OK' to delete, 'Cancel' to stop. " ), $key_js ) );
$r .= " ' ); \" class='deletemeta' tabindex='6' value=' " . attribute_escape ( __ ( 'Delete' )) . " ' /></td> " ;
2006-03-29 03:51:55 +02:00
$r .= " \n \t </tr> " ;
}
echo $r ;
echo " \n \t </tbody> " ;
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 ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
$keys = $wpdb -> get_col ( "
2005-09-18 21:44:14 +02:00
SELECT meta_key
FROM $wpdb -> postmeta
GROUP BY meta_key
2006-11-18 07:09:48 +01:00
ORDER BY meta_key " );
2005-09-18 21:44:14 +02:00
2004-03-23 19:02:05 +01:00
return $keys ;
}
function meta_form () {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2006-11-18 07:09:48 +01:00
$limit = ( int ) apply_filters ( 'postmeta_form_limit' , 30 );
$keys = $wpdb -> get_col ( "
2006-10-22 05:18:07 +02:00
SELECT meta_key
FROM $wpdb -> postmeta
GROUP BY meta_key
ORDER BY meta_id DESC
2006-11-18 07:09:48 +01:00
LIMIT $limit " );
2006-11-29 09:18:34 +01:00
if ( $keys )
natcasesort ( $keys );
2004-03-23 19:02:05 +01:00
?>
2006-11-18 07:09:48 +01:00
< h3 >< ? php _e ( 'Add a new custom field:' ) ?> </h3>
2006-03-29 03:51:55 +02:00
< table id = " newmeta " cellspacing = " 3 " cellpadding = " 3 " >
2004-04-28 04:23:46 +02:00
< tr >
2006-11-18 07:09:48 +01:00
< th colspan = " 2 " >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
2004-04-28 04:23:46 +02:00
</ tr >
< tr valign = " top " >
2004-05-20 13:32:14 +02:00
< td align = " right " width = " 18% " >
2006-10-22 05:18:07 +02:00
< ? php if ( $keys ) : ?>
2004-05-20 13:32:14 +02:00
< select id = " metakeyselect " name = " metakeyselect " tabindex = " 7 " >
2006-11-18 07:09:48 +01:00
< option value = " #NONE# " >< ? php _e ( '- Select -' ); ?> </option>
2004-03-23 19:02:05 +01:00
< ? php
2005-09-18 21:44:14 +02:00
2006-10-22 05:18:07 +02:00
foreach ( $keys as $key ) {
2006-12-21 11:10:04 +01:00
$key = attribute_escape ( $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
}
?>
2006-11-18 07:09:48 +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 >
2006-11-18 07:09:48 +01:00
< p class = " submit " >< input type = " submit " id = " updatemetasub " name = " updatemeta " tabindex = " 9 " value = " <?php _e( 'Add Custom Field »' ) ?> " /></ p >
2004-03-23 19:02:05 +01:00
< ? php
2005-09-18 21:44:14 +02:00
2004-03-23 19:02:05 +01:00
}
2006-11-18 07:09:48 +01:00
function add_meta ( $post_ID ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2006-03-29 03:51:55 +02:00
$post_ID = ( int ) $post_ID ;
2004-03-23 19:02:05 +01:00
2006-11-18 07:09:48 +01:00
$metakeyselect = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metakeyselect' ] ) ) );
$metakeyinput = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metakeyinput' ] ) ) );
$metavalue = maybe_serialize ( stripslashes ( ( trim ( $_POST [ 'metavalue' ] ) ) ));
$metavalue = $wpdb -> escape ( $metavalue );
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( ( '0' === $metavalue || ! 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:
2006-03-29 03:51:55 +02:00
if ( '#NONE#' != $metakeyselect )
2004-03-23 19:02:05 +01:00
$metakey = $metakeyselect ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( $metakeyinput )
2004-03-23 19:02:05 +01:00
$metakey = $metakeyinput ; // default
2006-11-18 07:09:48 +01:00
$result = $wpdb -> query ( "
2005-09-18 21:44:14 +02:00
INSERT INTO $wpdb -> postmeta
2006-11-18 07:09:48 +01:00
( post_id , meta_key , meta_value )
VALUES ( '$post_ID' , '$metakey' , '$metavalue' )
" );
2006-03-29 03:51:55 +02:00
return $wpdb -> insert_id ;
2004-03-23 19:02:05 +01:00
}
2006-03-29 03:51:55 +02:00
return false ;
2004-03-23 19:02:05 +01:00
} // add_meta
2006-11-18 07:09:48 +01:00
function delete_meta ( $mid ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2006-03-29 03:51:55 +02:00
$mid = ( int ) $mid ;
2004-04-28 04:23:46 +02:00
2006-11-18 07:09:48 +01:00
return $wpdb -> query ( " DELETE FROM $wpdb->postmeta WHERE meta_id = ' $mid ' " );
2004-03-23 19:02:05 +01:00
}
2006-11-18 07:09:48 +01:00
function update_meta ( $mid , $mkey , $mvalue ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2006-11-18 07:09:48 +01:00
$mvalue = maybe_serialize ( stripslashes ( $mvalue ));
$mvalue = $wpdb -> escape ( $mvalue );
2006-03-29 03:51:55 +02:00
$mid = ( int ) $mid ;
2006-11-18 07:09:48 +01: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
}
2006-11-18 07:09:48 +01:00
function get_post_meta_by_id ( $mid ) {
2006-03-29 03:51:55 +02:00
global $wpdb ;
$mid = ( int ) $mid ;
2006-11-18 07:09:48 +01:00
$meta = $wpdb -> get_row ( " SELECT * FROM $wpdb->postmeta WHERE meta_id = ' $mid ' " );
if ( is_serialized_string ( $meta -> meta_value ) )
$meta -> meta_value = maybe_unserialize ( $meta -> meta_value );
2006-10-24 11:14:47 +02:00
return $meta ;
2006-03-29 03:51:55 +02:00
}
2006-11-18 07:09:48 +01:00
function touch_time ( $edit = 1 , $for_post = 1 ) {
2006-04-02 02:20:11 +02:00
global $wp_locale , $post , $comment ;
2004-04-30 10:56:49 +02:00
2005-11-14 10:56:41 +01:00
if ( $for_post )
2006-11-18 07:09:48 +01:00
$edit = ( ( 'draft' == $post -> post_status ) && ( ! $post -> post_date || '0000-00-00 00:00:00' == $post -> post_date ) ) ? false : true ;
2005-11-14 10:56:41 +01:00
2006-11-18 07:09:48 +01:00
echo '<fieldset><legend><input type="checkbox" class="checkbox" name="edit_date" value="1" id="timestamp" /> <label for="timestamp">' . __ ( 'Edit timestamp' ) . '</label></legend>' ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
$time_adj = time () + ( get_option ( 'gmt_offset' ) * 3600 );
2005-07-17 21:02:05 +02:00
$post_date = ( $for_post ) ? $post -> post_date : $comment -> comment_date ;
2006-11-18 07:09:48 +01: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 );
2004-04-30 10:56:49 +02:00
2006-03-21 02:15:13 +01:00
echo " <select name= \" mm \" onchange= \" edit_date.checked=true \" > \n " ;
2006-11-18 07:09:48 +01:00
for ( $i = 1 ; $i < 13 ; $i = $i + 1 ) {
2004-04-30 10:56:49 +02:00
echo " \t \t \t <option value= \" $i\ " " ;
2006-11-18 07:09:48 +01:00
if ( $i == $mm )
2006-04-02 02:20:11 +02:00
echo ' selected="selected"' ;
2006-11-18 07:09:48 +01:00
echo '>' . $wp_locale -> get_month ( $i ) . " </option> \n " ;
2005-09-18 21:44:14 +02:00
}
2004-08-01 10:28:56 +02:00
?>
2004-04-30 10:56:49 +02:00
</ select >
2006-03-21 02:15:13 +01:00
< input type = " text " id = " jj " name = " jj " value = " <?php echo $jj ; ?> " size = " 2 " maxlength = " 2 " onchange = " edit_date.checked=true " />
2006-11-19 08:56:05 +01:00
< input type = " text " id = " aa " name = " aa " value = " <?php echo $aa ?> " size = " 4 " maxlength = " 5 " onchange = " edit_date.checked=true " /> @
< input type = " text " id = " hh " name = " hh " value = " <?php echo $hh ?> " size = " 2 " maxlength = " 2 " onchange = " edit_date.checked=true " /> :
< input type = " text " id = " mn " name = " mn " value = " <?php echo $mn ?> " size = " 2 " maxlength = " 2 " onchange = " edit_date.checked=true " />
< input type = " hidden " id = " ss " name = " ss " value = " <?php echo $ss ?> " size = " 2 " maxlength = " 2 " onchange = " edit_date.checked=true " />
2005-11-14 10:56:41 +01:00
< ? php
if ( $edit ) {
2006-12-22 00:06:18 +01:00
printf ( __ ( 'Existing timestamp: %1$s %2$s, %3$s @ %4$s:%5$s' ), $wp_locale -> get_month ( $mm ), $jj , $aa , $hh , $mn );
2005-09-18 21:44:14 +02:00
}
?>
2005-03-10 10:50:26 +01:00
</ fieldset >
2004-04-30 10:56:49 +02:00
< ? php
2005-09-18 21:44:14 +02:00
2004-04-30 10:56:49 +02:00
}
2005-08-20 03:56:27 +02:00
// insert_with_markers: Owen Winkler, fixed by Eric Anderson
2006-11-18 07:09:48 +01:00
// Inserts an array of strings into a file (.htaccess ), placing it between
2004-07-28 01:37:45 +02:00
// BEGIN and END markers. Replaces existing marked info. Retains surrounding
// data. Creates file if none exists.
// Returns true on write success, false on failure.
2006-11-18 07:09:48 +01:00
function insert_with_markers ( $filename , $marker , $insertion ) {
if ( ! file_exists ( $filename ) || is_writeable ( $filename ) ) {
if ( ! file_exists ( $filename ) ) {
2004-09-27 04:32:51 +02:00
$markerdata = '' ;
} else {
2006-11-18 07:09:48 +01:00
$markerdata = explode ( " \n " , implode ( '' , file ( $filename ) ) );
2004-09-27 04:32:51 +02:00
}
2006-11-18 07:09:48 +01:00
$f = fopen ( $filename , 'w' );
2004-09-27 04:32:51 +02:00
$foundit = false ;
2006-11-18 07:09:48 +01:00
if ( $markerdata ) {
2004-09-27 04:32:51 +02:00
$state = true ;
2006-11-18 07:09:48 +01:00
foreach ( $markerdata as $n => $markerline ) {
if ( strstr ( $markerline , " # BEGIN { $marker } " ))
2005-09-18 21:44:14 +02:00
$state = false ;
2006-11-18 07:09:48 +01:00
if ( $state ) {
if ( $n + 1 < count ( $markerdata ) )
fwrite ( $f , " { $markerline } \n " );
2006-04-04 02:51:47 +02:00
else
2006-11-18 07:09:48 +01:00
fwrite ( $f , " { $markerline } " );
2006-04-04 02:51:47 +02:00
}
2006-11-18 07:09:48 +01:00
if ( strstr ( $markerline , " # END { $marker } " ) ) {
fwrite ( $f , " # BEGIN { $marker } \n " );
if ( is_array ( $insertion ))
foreach ( $insertion as $insertline )
fwrite ( $f , " { $insertline } \n " );
fwrite ( $f , " # END { $marker } \n " );
2004-09-27 04:32:51 +02:00
$state = true ;
$foundit = true ;
}
}
}
if ( ! $foundit ) {
2006-11-18 07:09:48 +01:00
fwrite ( $f , " # BEGIN { $marker } \n " );
foreach ( $insertion as $insertline )
fwrite ( $f , " { $insertline } \n " );
fwrite ( $f , " # END { $marker } \n " );
2004-09-27 04:32:51 +02:00
}
2006-11-18 07:09:48 +01:00
fclose ( $f );
2004-09-27 04:32:51 +02:00
return true ;
} else {
return false ;
}
2004-07-28 01:37:45 +02:00
}
2005-08-20 03:56:27 +02:00
// extract_from_markers: Owen Winkler
2006-11-18 07:09:48 +01:00
// Returns an array of strings from a file (.htaccess ) from between BEGIN
2004-07-28 01:37:45 +02:00
// and END markers.
2006-11-18 07:09:48 +01:00
function extract_from_markers ( $filename , $marker ) {
2005-09-18 21:44:14 +02:00
$result = array ();
2004-07-28 01:37:45 +02:00
2006-11-18 07:09:48 +01:00
if ( ! file_exists ( $filename ) ) {
2004-09-27 04:32:51 +02:00
return $result ;
}
2006-11-18 07:09:48 +01:00
if ( $markerdata = explode ( " \n " , implode ( '' , file ( $filename ) ) ));
2004-09-27 04:32:51 +02:00
{
$state = false ;
2006-11-18 07:09:48 +01:00
foreach ( $markerdata as $markerline ) {
if ( strstr ( $markerline , " # END { $marker } " ))
2005-09-18 21:44:14 +02:00
$state = false ;
2006-11-18 07:09:48 +01:00
if ( $state )
2005-09-18 21:44:14 +02:00
$result [] = $markerline ;
2006-11-18 07:09:48 +01:00
if ( strstr ( $markerline , " # BEGIN { $marker } " ))
2005-09-18 21:44:14 +02:00
$state = true ;
2004-09-27 04:32:51 +02:00
}
}
return $result ;
2004-07-28 01:37:45 +02:00
}
2005-11-11 00:25:39 +01:00
function got_mod_rewrite () {
global $is_apache ;
// take 3 educated guesses as to whether or not mod_rewrite is available
if ( ! $is_apache )
return false ;
2006-11-18 07:09:48 +01:00
if ( function_exists ( 'apache_get_modules' ) ) {
if ( ! in_array ( 'mod_rewrite' , apache_get_modules () ) )
2005-11-11 00:25:39 +01:00
return false ;
}
return true ;
}
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
2006-11-18 07:09:48 +01:00
if ( ! $wp_rewrite -> using_mod_rewrite_permalinks () )
2006-12-01 13:07:01 +01:00
return false ;
2004-12-27 23:30:52 +01:00
2006-11-18 07:09:48 +01:00
if ( ! (( ! file_exists ( $home_path . '.htaccess' ) && is_writable ( $home_path ) ) || is_writable ( $home_path . '.htaccess' ) ) )
2006-12-01 13:07:01 +01:00
return false ;
2004-12-27 23:30:52 +01:00
2006-11-18 07:09:48 +01:00
if ( ! got_mod_rewrite () )
2006-12-01 13:07:01 +01:00
return false ;
2004-12-27 23:30:52 +01:00
2006-11-18 07:09:48 +01:00
$rules = explode ( " \n " , $wp_rewrite -> mod_rewrite_rules () );
2006-12-01 13:07:01 +01:00
return insert_with_markers ( $home_path . '.htaccess' , 'WordPress' , $rules );
2004-10-06 04:18:37 +02:00
}
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' ];
2005-09-18 21:44:14 +02:00
$page_templates = array ();
2004-10-06 07:11:11 +02:00
2006-11-18 07:09:48 +01:00
if ( is_array ( $templates ) ) {
foreach ( $templates as $template ) {
$template_data = implode ( '' , file ( ABSPATH . $template ));
2006-12-05 13:29:08 +01:00
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
2006-11-18 07:09:48 +01:00
if ( ! empty ( $name ) ) {
$page_templates [ trim ( $name )] = basename ( $template );
2005-03-23 02:14:05 +01:00
}
2004-10-06 07:11:11 +02:00
}
}
return $page_templates ;
}
2006-11-18 07:09:48 +01:00
function page_template_dropdown ( $default = '' ) {
2004-10-06 07:11:11 +02:00
$templates = get_page_templates ();
2006-11-18 07:09:48 +01:00
foreach ( array_keys ( $templates ) as $template )
: if ( $default == $templates [ $template ] )
2005-09-18 21:44:14 +02:00
$selected = " selected='selected' " ;
else
$selected = '' ;
echo " \n \t <option value=' " . $templates [ $template ] . " ' $selected > $template </option> " ;
endforeach ;
2004-10-06 07:11:11 +02:00
}
2006-11-18 07:09:48 +01:00
function parent_dropdown ( $default = 0 , $parent = 0 , $level = 0 ) {
2004-11-24 01:12:46 +01:00
global $wpdb , $post_ID ;
2006-11-18 07:09:48 +01:00
$items = $wpdb -> get_results ( " SELECT ID, post_parent, post_title FROM $wpdb->posts WHERE post_parent = $parent AND post_type = 'page' ORDER BY menu_order " );
2004-11-24 01:12:46 +01:00
2006-11-18 07:09:48 +01:00
if ( $items ) {
foreach ( $items as $item ) {
2007-01-24 08:17:14 +01:00
// A page cannot be its own parent.
2006-11-18 07:09:48 +01:00
if ( ! empty ( $post_ID ) ) {
if ( $item -> ID == $post_ID ) {
2004-11-24 01:12:46 +01:00
continue ;
}
}
2006-11-18 07:09:48 +01:00
$pad = str_repeat ( ' ' , $level * 3 );
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> " ;
2006-11-18 07:09:48 +01: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 ;
2006-08-15 23:03:11 +02:00
global $_wp_menu_nopriv ;
global $_wp_submenu_nopriv ;
2006-07-27 00:18:36 +02:00
global $plugin_page ;
2004-10-18 06:50:08 +02:00
2004-12-08 23:32:49 +01:00
$parent = get_admin_page_parent ();
2006-11-18 17:24:31 +01:00
2006-11-18 07:09:48 +01:00
if ( isset ( $_wp_submenu_nopriv [ $parent ][ $pagenow ] ) )
2006-02-17 01:57:10 +01:00
return false ;
2004-10-18 06:50:08 +02:00
2006-11-18 07:09:48 +01:00
if ( isset ( $plugin_page ) && isset ( $_wp_submenu_nopriv [ $parent ][ $plugin_page ] ) )
2006-07-27 00:18:36 +02:00
return false ;
2007-02-27 16:24:54 +01:00
2006-11-18 07:09:48 +01:00
if ( empty ( $parent ) ) {
if ( isset ( $_wp_menu_nopriv [ $pagenow ] ) )
2006-08-16 00:13:36 +02:00
return false ;
2006-11-18 07:09:48 +01:00
if ( isset ( $_wp_submenu_nopriv [ $pagenow ][ $pagenow ] ) )
2006-08-16 00:13:36 +02:00
return false ;
2006-11-18 07:09:48 +01:00
if ( isset ( $plugin_page ) && isset ( $_wp_submenu_nopriv [ $pagenow ][ $plugin_page ] ) )
2006-08-16 00:13:36 +02:00
return false ;
2006-11-18 07:09:48 +01:00
foreach ( array_keys ( $_wp_submenu_nopriv ) as $key ) {
if ( isset ( $_wp_submenu_nopriv [ $key ][ $pagenow ] ) )
2006-08-16 00:13:36 +02:00
return false ;
2006-11-18 07:09:48 +01:00
if ( isset ( $plugin_page ) && isset ( $_wp_submenu_nopriv [ $key ][ $plugin_page ] ) )
2007-02-27 16:24:54 +01:00
return false ;
2006-08-16 00:13:36 +02:00
}
return true ;
}
2004-10-18 06:50:08 +02:00
2006-11-18 07:09:48 +01:00
if ( isset ( $submenu [ $parent ] ) ) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
2006-11-18 17:24:31 +01:00
if ( isset ( $plugin_page ) && ( $submenu_array [ 2 ] == $plugin_page ) ) {
if ( current_user_can ( $submenu_array [ 1 ] ))
return true ;
else
return false ;
} else if ( $submenu_array [ 2 ] == $pagenow ) {
2006-11-18 07:09:48 +01:00
if ( current_user_can ( $submenu_array [ 1 ] ))
2004-10-18 06:50:08 +02:00
return true ;
2006-02-17 01:57:10 +01:00
else
return false ;
2004-10-18 06:50:08 +02:00
}
}
}
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
foreach ( $menu as $menu_array ) {
if ( $menu_array [ 2 ] == $parent ) {
if ( current_user_can ( $menu_array [ 1 ] ))
2006-02-17 01:57:10 +01:00
return true ;
else
return false ;
}
}
2006-11-19 08:56:05 +01:00
2004-10-18 06:50:08 +02:00
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 ;
2006-11-18 07:09:48 +01:00
if ( isset ( $title ) && ! empty ( $title ) ) {
2004-10-19 05:03:06 +02:00
return $title ;
}
2006-11-18 07:09:48 +01:00
$hook = get_plugin_page_hook ( $plugin_page , $pagenow );
2005-12-28 01:45:13 +01:00
$parent = $parent1 = get_admin_page_parent ();
2006-11-18 07:09:48 +01:00
if ( empty ( $parent ) ) {
foreach ( $menu as $menu_array ) {
if ( isset ( $menu_array [ 3 ] ) ) {
if ( $menu_array [ 2 ] == $pagenow ) {
2005-01-30 08:34:03 +01:00
$title = $menu_array [ 3 ];
return $menu_array [ 3 ];
2005-09-18 21:44:14 +02:00
} else
2006-11-18 07:09:48 +01:00
if ( isset ( $plugin_page ) && ( $plugin_page == $menu_array [ 2 ] ) && ( $hook == $menu_array [ 3 ] ) ) {
2005-09-18 21:44:14 +02:00
$title = $menu_array [ 3 ];
return $menu_array [ 3 ];
}
2006-11-18 07:09:48 +01:00
} else {
$title = $menu_array [ 0 ];
return $title ;
2005-01-30 08:34:03 +01:00
}
}
} else {
2006-11-18 07:09:48 +01:00
foreach ( array_keys ( $submenu ) as $parent ) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( isset ( $plugin_page ) &&
( $plugin_page == $submenu_array [ 2 ] ) &&
(( $parent == $pagenow ) || ( $parent == $plugin_page ) || ( $plugin_page == $hook ) || (( $pagenow == 'admin.php' ) && ( $parent1 != $submenu_array [ 2 ] ) ) )
) {
2005-01-30 08:34:03 +01:00
$title = $submenu_array [ 3 ];
return $submenu_array [ 3 ];
2006-11-18 07:09:48 +01:00
}
if ( $submenu_array [ 2 ] != $pagenow || isset ( $_GET [ 'page' ] ) ) // not the current page
continue ;
if ( isset ( $submenu_array [ 3 ] ) ) {
$title = $submenu_array [ 3 ];
return $submenu_array [ 3 ];
} else {
$title = $submenu_array [ 0 ];
return $title ;
2004-10-19 05:03:06 +02:00
}
}
}
}
2006-11-18 07:09:48 +01:00
return $title ;
2004-10-19 05:03:06 +02:00
}
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 ;
2006-08-15 23:03:11 +02:00
global $_wp_real_parent_file ;
global $_wp_menu_nopriv ;
global $_wp_submenu_nopriv ;
2006-02-17 01:57:10 +01:00
2006-11-18 07:09:48 +01:00
if ( ! empty ( $parent_file ) ) {
if ( isset ( $_wp_real_parent_file [ $parent_file ] ) )
2006-08-15 23:03:11 +02:00
$parent_file = $_wp_real_parent_file [ $parent_file ];
2004-10-19 05:03:06 +02:00
return $parent_file ;
}
2006-11-18 07:09:48 +01:00
if ( $pagenow == 'admin.php' && isset ( $plugin_page ) ) {
foreach ( $menu as $parent_menu ) {
if ( $parent_menu [ 2 ] == $plugin_page ) {
2005-02-25 17:11:27 +01:00
$parent_file = $plugin_page ;
2006-11-18 07:09:48 +01:00
if ( isset ( $_wp_real_parent_file [ $parent_file ] ) )
2006-08-15 23:03:11 +02:00
$parent_file = $_wp_real_parent_file [ $parent_file ];
2006-02-17 01:57:10 +01:00
return $parent_file ;
2005-02-25 17:11:27 +01:00
}
}
2006-11-18 07:09:48 +01:00
if ( isset ( $_wp_menu_nopriv [ $plugin_page ] ) ) {
2006-08-15 23:03:11 +02:00
$parent_file = $plugin_page ;
2006-11-18 07:09:48 +01:00
if ( isset ( $_wp_real_parent_file [ $parent_file ] ) )
2006-08-15 23:03:11 +02:00
$parent_file = $_wp_real_parent_file [ $parent_file ];
return $parent_file ;
2007-02-27 16:24:54 +01:00
}
2006-08-15 23:03:11 +02:00
}
2006-11-18 07:09:48 +01:00
if ( isset ( $plugin_page ) && isset ( $_wp_submenu_nopriv [ $pagenow ][ $plugin_page ] ) ) {
2006-08-15 23:03:11 +02:00
$parent_file = $pagenow ;
2006-11-18 07:09:48 +01:00
if ( isset ( $_wp_real_parent_file [ $parent_file ] ) )
2006-08-15 23:03:11 +02:00
$parent_file = $_wp_real_parent_file [ $parent_file ];
2007-02-27 16:24:54 +01:00
return $parent_file ;
2005-02-25 17:11:27 +01:00
}
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
foreach ( array_keys ( $submenu ) as $parent ) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( isset ( $_wp_real_parent_file [ $parent ] ) )
2006-08-15 23:03:11 +02:00
$parent = $_wp_real_parent_file [ $parent ];
2006-11-18 07:09:48 +01:00
if ( $submenu_array [ 2 ] == $pagenow ) {
2004-10-19 05:03:06 +02:00
$parent_file = $parent ;
return $parent ;
2005-09-18 21:44:14 +02:00
} else
2006-11-18 07:09:48 +01:00
if ( isset ( $plugin_page ) && ( $plugin_page == $submenu_array [ 2 ] ) ) {
2005-09-18 21:44:14 +02:00
$parent_file = $parent ;
return $parent ;
}
2004-10-19 05:03:06 +02:00
}
}
$parent_file = '' ;
return '' ;
}
2006-11-18 07:09:48 +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
2006-11-18 07:09:48 +01:00
$file = plugin_basename ( $file );
2004-11-26 02:50:37 +01:00
2006-11-18 07:09:48 +01:00
$menu [] = array ( $menu_title , $access_level , $file , $page_title );
2005-02-07 02:15:06 +01:00
2006-11-18 07:09:48 +01:00
$admin_page_hooks [ $file ] = sanitize_title ( $menu_title );
2005-02-25 17:11:27 +01:00
2006-11-18 07:09:48 +01:00
$hookname = get_plugin_page_hookname ( $file , '' );
if ( ! empty ( $function ) && ! empty ( $hookname ))
add_action ( $hookname , $function );
2005-02-25 17:11:27 +01:00
return $hookname ;
2004-11-26 02:50:37 +01:00
}
2006-11-18 07:09:48 +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 ;
2006-08-15 23:03:11 +02:00
global $_wp_real_parent_file ;
global $_wp_submenu_nopriv ;
global $_wp_menu_nopriv ;
2006-08-14 23:24:43 +02:00
2006-11-18 07:09:48 +01:00
$file = plugin_basename ( $file );
2006-08-15 23:03:11 +02:00
2006-11-18 07:09:48 +01:00
$parent = plugin_basename ( $parent );
if ( isset ( $_wp_real_parent_file [ $parent ] ) )
2006-08-15 23:03:11 +02:00
$parent = $_wp_real_parent_file [ $parent ];
2006-11-18 07:09:48 +01:00
if ( ! current_user_can ( $access_level ) ) {
2006-08-15 23:03:11 +02:00
$_wp_submenu_nopriv [ $parent ][ $file ] = true ;
2006-08-14 23:24:43 +02:00
return false ;
}
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.
2006-11-18 07:09:48 +01:00
if ( ! isset ( $submenu [ $parent ] ) && $file != $parent ) {
foreach ( $menu as $parent_menu ) {
2006-11-18 17:24:31 +01:00
if ( $parent_menu [ 2 ] == $parent && current_user_can ( $parent_menu [ 1 ] ) )
2004-12-04 06:02:07 +01:00
$submenu [ $parent ][] = $parent_menu ;
}
}
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
$submenu [ $parent ][] = array ( $menu_title , $access_level , $file , $page_title );
2005-02-07 02:15:06 +01:00
2006-11-18 07:09:48 +01:00
$hookname = get_plugin_page_hookname ( $file , $parent );
if ( ! empty ( $function ) && ! empty ( $hookname ))
add_action ( $hookname , $function );
2005-02-07 02:15:06 +01:00
return $hookname ;
2004-10-18 06:50:08 +02:00
}
2006-11-18 07:09:48 +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
}
2006-11-18 07:09:48 +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
2006-11-18 07:09:48 +01:00
function add_theme_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
return add_submenu_page ( 'themes.php' , $page_title , $menu_title , $access_level , $file , $function );
2005-08-30 01:40:32 +02:00
}
2006-11-18 07:09:48 +01:00
function validate_file ( $file , $allowed_files = '' ) {
if ( false !== strpos ( $file , './' ))
2004-12-30 19:05:46 +01:00
return 1 ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( ':' == substr ( $file , 1 , 1 ))
2004-12-30 19:05:46 +01:00
return 2 ;
2006-11-18 07:09:48 +01:00
if ( ! empty ( $allowed_files ) && ( ! in_array ( $file , $allowed_files ) ) )
2004-12-30 19:05:46 +01:00
return 3 ;
return 0 ;
}
2006-11-18 07:09:48 +01:00
function validate_file_to_edit ( $file , $allowed_files = '' ) {
$file = stripslashes ( $file );
2004-12-30 19:05:46 +01:00
2006-11-18 07:09:48 +01:00
$code = validate_file ( $file , $allowed_files );
2004-12-30 19:05:46 +01:00
2006-11-18 07:09:48 +01:00
if ( ! $code )
2004-12-30 19:05:46 +01:00
return $file ;
2006-11-18 07:09:48 +01:00
switch ( $code ) {
2005-09-18 21:44:14 +02:00
case 1 :
2006-11-18 07:09:48 +01:00
wp_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.' ));
2005-09-18 21:44:14 +02:00
case 2 :
2006-11-18 07:09:48 +01:00
wp_die ( __ ( 'Sorry, can’t call files with their real path.' ));
2004-11-17 04:15:44 +01:00
2005-09-18 21:44:14 +02:00
case 3 :
2006-11-18 07:09:48 +01:00
wp_die ( __ ( 'Sorry, that file cannot be edited.' ));
2004-11-17 04:15:44 +01:00
}
}
2004-12-23 01:53:56 +01:00
function get_home_path () {
2006-11-18 07:09:48 +01:00
$home = get_option ( 'home' );
if ( $home != '' && $home != get_option ( 'siteurl' ) ) {
$home_path = parse_url ( $home );
2005-02-01 07:59:44 +01:00
$home_path = $home_path [ 'path' ];
2006-11-18 07:09:48 +01:00
$root = str_replace ( $_SERVER [ " PHP_SELF " ], '' , $_SERVER [ " SCRIPT_FILENAME " ] );
$home_path = trailingslashit ( $root . $home_path );
2004-12-23 01:53:56 +01:00
} else {
$home_path = ABSPATH ;
}
return $home_path ;
}
2006-11-18 07:09:48 +01:00
function get_real_file_to_edit ( $file ) {
if ( 'index.php' == $file || '.htaccess' == $file ) {
2005-09-18 21:44:14 +02:00
$real_file = get_home_path () . $file ;
2004-11-17 04:15:44 +01:00
} else {
2005-09-18 21:44:14 +02:00
$real_file = ABSPATH . $file ;
2004-11-17 04:15:44 +01:00
}
return $real_file ;
}
2006-11-18 07:09:48 +01:00
$wp_file_descriptions = array ( 'index.php' => __ ( 'Main Index Template' ), 'style.css' => __ ( 'Stylesheet' ), 'comments.php' => __ ( 'Comments' ), 'comments-popup.php' => __ ( 'Popup Comments' ), 'footer.php' => __ ( 'Footer' ), 'header.php' => __ ( 'Header' ), 'sidebar.php' => __ ( 'Sidebar' ), 'archive.php' => __ ( 'Archives' ), 'category.php' => __ ( 'Category Template' ), 'page.php' => __ ( 'Page Template' ), 'search.php' => __ ( 'Search Results' ), 'single.php' => __ ( 'Single Post' ), '404.php' => __ ( '404 Template' ), 'my-hacks.php' => __ ( 'my-hacks.php (legacy hacks support)' ), '.htaccess' => __ ( '.htaccess (for rewrite rules )' ),
2005-01-19 16:23:38 +01:00
// Deprecated files
2006-11-18 07:09:48 +01:00
'wp-layout.css' => __ ( 'Stylesheet' ), 'wp-comments.php' => __ ( 'Comments Template' ), 'wp-comments-popup.php' => __ ( 'Popup Comments Template' ));
2004-11-17 04:15:44 +01:00
2006-11-18 07:09:48 +01:00
function get_file_description ( $file ) {
2004-11-17 04:15:44 +01:00
global $wp_file_descriptions ;
2006-11-18 07:09:48 +01:00
if ( isset ( $wp_file_descriptions [ basename ( $file )] ) ) {
return $wp_file_descriptions [ basename ( $file )];
2005-09-18 21:44:14 +02:00
}
2006-05-10 22:35:10 +02:00
elseif ( file_exists ( ABSPATH . $file ) && is_file ( ABSPATH . $file ) ) {
2006-11-18 07:09:48 +01:00
$template_data = implode ( '' , file ( ABSPATH . $file ) );
2007-01-25 20:42:30 +01:00
if ( preg_match ( " |Template Name:(.*)|i " , $template_data , $name ))
2005-02-14 05:24:25 +01:00
return $name [ 1 ];
2004-11-17 04:15:44 +01:00
}
2006-11-18 07:09:48 +01:00
return basename ( $file );
2004-11-17 04:15:44 +01:00
}
2006-11-18 07:09:48 +01:00
function update_recently_edited ( $file ) {
$oldfiles = ( array ) get_option ( 'recently_edited' );
if ( $oldfiles ) {
$oldfiles = array_reverse ( $oldfiles );
2004-11-17 04:15:44 +01:00
$oldfiles [] = $file ;
2006-11-18 07:09:48 +01:00
$oldfiles = array_reverse ( $oldfiles );
$oldfiles = array_unique ( $oldfiles );
if ( 5 < count ( $oldfiles ))
array_pop ( $oldfiles );
2004-11-17 04:15:44 +01:00
} else {
$oldfiles [] = $file ;
}
2006-11-18 07:09:48 +01:00
update_option ( 'recently_edited' , $oldfiles );
2004-11-17 04:15:44 +01:00
}
2006-11-18 07:09:48 +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 = trim ( $version [ 1 ] );
2004-11-26 03:29:45 +01:00
else
2005-09-18 21:44:14 +02:00
$version = '' ;
2004-11-26 03:29:45 +01:00
2006-11-18 07:09:48 +01:00
$description = wptexturize ( trim ( $description [ 1 ] ));
2004-11-26 03:29:45 +01:00
$name = $plugin_name [ 1 ];
2006-11-18 07:09:48 +01:00
$name = trim ( $name );
2004-11-26 03:29:45 +01:00
$plugin = $name ;
2006-11-18 07:09:48 +01:00
if ( '' != $plugin_uri [ 1 ] && '' != $name ) {
$plugin = '<a href="' . trim ( $plugin_uri [ 1 ] ) . '" title="' . __ ( 'Visit plugin homepage' ) . '">' . $plugin . '</a>' ;
2004-11-26 03:29:45 +01:00
}
2006-11-18 07:09:48 +01:00
if ( '' == $author_uri [ 1 ] ) {
$author = trim ( $author_name [ 1 ] );
2004-11-26 03:29:45 +01:00
} else {
2006-11-18 07:09:48 +01:00
$author = '<a href="' . trim ( $author_uri [ 1 ] ) . '" title="' . __ ( 'Visit author homepage' ) . '">' . trim ( $author_name [ 1 ] ) . '</a>' ;
2004-11-26 03:29:45 +01:00
}
2006-11-18 07:09:48 +01:00
return array ( 'Name' => $name , 'Title' => $plugin , 'Description' => $description , 'Author' => $author , 'Version' => $version , 'Template' => $template [ 1 ] );
2004-11-26 03:29:45 +01:00
}
function get_plugins () {
global $wp_plugins ;
2006-11-18 07:09:48 +01:00
if ( isset ( $wp_plugins ) ) {
2004-11-26 03:29:45 +01:00
return $wp_plugins ;
}
2005-09-18 21:44:14 +02:00
$wp_plugins = array ();
2006-09-21 22:46:39 +02:00
$plugin_root = ABSPATH . PLUGINDIR ;
2004-11-26 03:29:45 +01:00
// Files in wp-content/plugins directory
2006-11-18 07:09:48 +01:00
$plugins_dir = @ dir ( $plugin_root );
if ( $plugins_dir ) {
while (( $file = $plugins_dir -> read () ) !== false ) {
if ( preg_match ( '|^\.+$|' , $file ))
2004-11-28 01:33:04 +01:00
continue ;
2006-11-18 07:09:48 +01:00
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 ))
2004-11-28 01:33:04 +01:00
continue ;
2006-11-18 07:09:48 +01:00
if ( preg_match ( '|\.php$|' , $subfile ))
2004-11-28 01:33:04 +01:00
$plugin_files [] = " $file / $subfile " ;
}
}
} else {
2006-11-18 07:09:48 +01:00
if ( preg_match ( '|\.php$|' , $file ))
2004-11-28 01:33:04 +01:00
$plugin_files [] = $file ;
}
2004-11-26 03:29:45 +01:00
}
}
2006-10-04 11:36:21 +02:00
if ( ! $plugins_dir || ! $plugin_files )
2004-11-26 03:29:45 +01:00
return $wp_plugins ;
2006-10-04 11:36:21 +02:00
foreach ( $plugin_files as $plugin_file ) {
2006-11-18 07:09:48 +01:00
if ( ! is_readable ( " $plugin_root / $plugin_file " ) )
2005-11-16 04:27:22 +01:00
continue ;
2006-11-18 07:09:48 +01:00
$plugin_data = get_plugin_data ( " $plugin_root / $plugin_file " );
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
if ( empty ( $plugin_data [ 'Name' ] ) )
2004-11-26 03:29:45 +01:00
continue ;
2006-11-18 07:09:48 +01:00
$wp_plugins [ plugin_basename ( $plugin_file )] = $plugin_data ;
2004-11-26 03:29:45 +01:00
}
2006-11-18 07:09:48 +01:00
uasort ( $wp_plugins , create_function ( '$a, $b' , 'return strnatcasecmp( $a["Name"], $b["Name"] );' ));
2006-10-04 11:36:21 +02:00
2004-11-26 03:29:45 +01:00
return $wp_plugins ;
}
2006-11-18 07:09:48 +01:00
function get_plugin_page_hookname ( $plugin_page , $parent_page ) {
2005-02-07 02:15:06 +01:00
global $admin_page_hooks ;
2005-02-25 17:11:27 +01:00
$parent = get_admin_page_parent ();
2006-11-18 07:09:48 +01:00
if ( empty ( $parent_page ) || 'admin.php' == $parent_page ) {
if ( isset ( $admin_page_hooks [ $plugin_page ] ))
2005-02-25 17:11:27 +01:00
$page_type = 'toplevel' ;
2005-09-18 21:44:14 +02:00
else
2006-11-18 07:09:48 +01:00
if ( isset ( $admin_page_hooks [ $parent ] ))
2005-09-18 21:44:14 +02:00
$page_type = $admin_page_hooks [ $parent ];
} else
2006-11-18 07:09:48 +01:00
if ( isset ( $admin_page_hooks [ $parent_page ] ) ) {
2005-09-18 21:44:14 +02:00
$page_type = $admin_page_hooks [ $parent_page ];
} else {
$page_type = 'admin' ;
}
2005-02-07 02:15:06 +01:00
2006-11-18 07:09:48 +01:00
$plugin_name = preg_replace ( '!\.php!' , '' , $plugin_page );
2005-02-07 02:15:06 +01:00
2005-09-18 21:44:14 +02:00
return $page_type . '_page_' . $plugin_name ;
2005-02-07 02:15:06 +01:00
}
2006-11-18 07:09:48 +01:00
function get_plugin_page_hook ( $plugin_page , $parent_page ) {
2005-02-07 02:15:06 +01:00
global $wp_filter ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
$hook = get_plugin_page_hookname ( $plugin_page , $parent_page );
if ( isset ( $wp_filter [ $hook ] ))
2005-02-07 02:15:06 +01:00
return $hook ;
else
return '' ;
}
2005-08-27 21:18:26 +02:00
function browse_happy () {
2006-11-18 07:09:48 +01:00
$getit = __ ( 'WordPress recommends a better browser' );
2005-04-19 04:16:57 +02:00
echo '
2005-09-18 21:44:14 +02:00
< p id = " bh " style = " text-align: center; " >< a href = " http://browsehappy.com/ " title = " '. $getit .' " >< img src = " images/browse-happy.gif " alt = " Browse Happy " /></ a ></ p >
' ;
2005-04-19 04:16:57 +02:00
}
2006-11-18 07:09:48 +01:00
if ( strstr ( $_SERVER [ 'HTTP_USER_AGENT' ], 'MSIE' ))
add_action ( 'admin_footer' , 'browse_happy' );
2005-04-19 04:16:57 +02:00
2006-11-18 07:09:48 +01:00
function documentation_link ( $for ) {
2005-07-09 00:59:15 +02:00
return ;
}
2006-11-18 07:09:48 +01:00
function register_importer ( $id , $name , $description , $callback ) {
2005-08-21 09:03:23 +02:00
global $wp_importers ;
2005-09-18 21:44:14 +02:00
2006-11-18 07:09:48 +01:00
$wp_importers [ $id ] = array ( $name , $description , $callback );
2005-08-21 09:03:23 +02:00
}
function get_importers () {
global $wp_importers ;
return $wp_importers ;
}
2005-09-06 01:33:10 +02:00
function current_theme_info () {
$themes = get_themes ();
$current_theme = get_current_theme ();
2006-01-24 08:38:29 +01:00
$ct -> name = $current_theme ;
2005-09-06 01:33:10 +02:00
$ct -> title = $themes [ $current_theme ][ 'Title' ];
$ct -> version = $themes [ $current_theme ][ 'Version' ];
$ct -> parent_theme = $themes [ $current_theme ][ 'Parent Theme' ];
$ct -> template_dir = $themes [ $current_theme ][ 'Template Dir' ];
$ct -> stylesheet_dir = $themes [ $current_theme ][ 'Stylesheet Dir' ];
$ct -> template = $themes [ $current_theme ][ 'Template' ];
$ct -> stylesheet = $themes [ $current_theme ][ 'Stylesheet' ];
$ct -> screenshot = $themes [ $current_theme ][ 'Screenshot' ];
$ct -> description = $themes [ $current_theme ][ 'Description' ];
$ct -> author = $themes [ $current_theme ][ 'Author' ];
return $ct ;
}
2005-09-27 01:55:36 +02:00
2005-11-01 22:28:03 +01:00
// array wp_handle_upload ( array &file [, array overrides] )
// file: reference to a single element of $_FILES. Call the function once for each uploaded file.
2006-11-18 07:09:48 +01:00
// overrides: an associative array of names=>values to override default variables with extract( $overrides, EXTR_OVERWRITE ).
2005-11-01 22:28:03 +01:00
// On success, returns an associative array of file attributes.
2006-11-18 07:09:48 +01:00
// On failure, returns $overrides['upload_error_handler'](&$file, $message ) or array( 'error'=>$message ).
function wp_handle_upload ( & $file , $overrides = false ) {
2005-11-01 22:28:03 +01:00
// The default error handler.
2006-11-18 07:09:48 +01:00
if ( ! function_exists ( 'wp_handle_upload_error' ) ) {
function wp_handle_upload_error ( & $file , $message ) {
return array ( 'error' => $message );
2005-12-13 20:19:56 +01:00
}
2005-11-01 22:28:03 +01:00
}
// You may define your own function and pass the name in $overrides['upload_error_handler']
$upload_error_handler = 'wp_handle_upload_error' ;
// $_POST['action'] must be set and its value must equal $overrides['action'] or this:
$action = 'wp_handle_upload' ;
// Courtesy of php.net, the strings that describe the error indicated in $_FILES[{form field}]['error'].
2006-11-18 07:09:48 +01:00
$upload_error_strings = array ( false ,
__ ( " The uploaded file exceeds the <code>upload_max_filesize</code> directive in <code>php.ini</code>. " ),
__ ( " The uploaded file exceeds the <em>MAX_FILE_SIZE</em> directive that was specified in the HTML form. " ),
__ ( " The uploaded file was only partially uploaded. " ),
__ ( " No file was uploaded. " ),
__ ( " Missing a temporary folder. " ),
__ ( " Failed to write file to disk. " ));
2005-11-01 22:28:03 +01:00
// All tests are on by default. Most can be turned off by $override[{test_name}] = false;
$test_form = true ;
$test_size = true ;
2005-12-13 20:19:56 +01:00
// If you override this, you must provide $ext and $type!!!!
2005-11-01 22:28:03 +01:00
$test_type = true ;
// Install user overrides. Did we mention that this voids your warranty?
2006-11-18 07:09:48 +01:00
if ( is_array ( $overrides ) )
extract ( $overrides , EXTR_OVERWRITE );
2005-11-01 22:28:03 +01:00
// A correct form post will pass this test.
2006-11-18 07:09:48 +01:00
if ( $test_form && ( ! isset ( $_POST [ 'action' ] ) || ( $_POST [ 'action' ] != $action ) ) )
return $upload_error_handler ( $file , __ ( 'Invalid form submission.' ));
2005-11-01 22:28:03 +01:00
// A successful upload will pass this test. It makes no sense to override this one.
if ( $file [ 'error' ] > 0 )
2006-11-18 07:09:48 +01:00
return $upload_error_handler ( $file , $upload_error_strings [ $file [ 'error' ]] );
2005-11-01 22:28:03 +01:00
// A non-empty file will pass this test.
2006-11-18 07:09:48 +01:00
if ( $test_size && ! ( $file [ 'size' ] > 0 ) )
return $upload_error_handler ( $file , __ ( 'File is empty. Please upload something more substantial.' ));
2005-11-01 22:28:03 +01:00
// A properly uploaded file will pass this test. There should be no reason to override this one.
2006-11-18 07:09:48 +01:00
if ( ! @ is_uploaded_file ( $file [ 'tmp_name' ] ) )
return $upload_error_handler ( $file , __ ( 'Specified file failed upload test.' ));
2005-11-01 22:28:03 +01:00
2006-06-22 01:17:19 +02:00
// A correct MIME type will pass this test. Override $mimes or use the upload_mimes filter.
2005-11-01 22:28:03 +01:00
if ( $test_type ) {
2006-11-18 07:09:48 +01:00
$wp_filetype = wp_check_filetype ( $file [ 'name' ], $mimes );
2006-06-22 01:17:19 +02:00
2006-11-18 07:09:48 +01:00
extract ( $wp_filetype );
2005-12-13 20:19:56 +01:00
if ( ! $type || ! $ext )
2006-11-18 07:09:48 +01:00
return $upload_error_handler ( $file , __ ( 'File type does not meet security guidelines. Try another.' ));
2005-11-01 22:28:03 +01:00
}
// A writable uploads dir will pass this test. Again, there's no point overriding this one.
if ( ! ( ( $uploads = wp_upload_dir () ) && false === $uploads [ 'error' ] ) )
2006-11-18 07:09:48 +01:00
return $upload_error_handler ( $file , $uploads [ 'error' ] );
2005-11-01 22:28:03 +01:00
// Increment the file number until we have a unique file to save in $dir. Use $override['unique_filename_callback'] if supplied.
2006-11-18 07:09:48 +01:00
if ( isset ( $unique_filename_callback ) && function_exists ( $unique_filename_callback ) ) {
$filename = $unique_filename_callback ( $uploads [ 'path' ], $file [ 'name' ] );
2005-11-01 22:28:03 +01:00
} else {
$number = '' ;
2006-11-18 07:09:48 +01:00
$filename = str_replace ( '#' , '_' , $file [ 'name' ] );
$filename = str_replace ( array ( '\\' , " ' " ), '' , $filename );
if ( empty ( $ext ) )
2005-12-29 02:25:41 +01:00
$ext = '' ;
else
$ext = " . $ext " ;
2006-11-18 07:09:48 +01:00
while ( file_exists ( $uploads [ 'path' ] . " / $filename " ) ) {
2005-12-29 02:25:41 +01:00
if ( '' == " $number $ext " )
$filename = $filename . ++ $number . $ext ;
else
2006-11-18 07:09:48 +01:00
$filename = str_replace ( " $number $ext " , ++ $number . $ext , $filename );
2005-12-29 02:25:41 +01:00
}
2006-11-18 07:09:48 +01:00
$filename = str_replace ( $ext , '' , $filename );
$filename = sanitize_title_with_dashes ( $filename ) . $ext ;
2005-11-01 22:28:03 +01:00
}
// Move the file to the uploads dir
$new_file = $uploads [ 'path' ] . " / $filename " ;
2006-11-18 07:09:48 +01:00
if ( false === @ move_uploaded_file ( $file [ 'tmp_name' ], $new_file ) )
wp_die ( printf ( __ ( 'The uploaded file could not be moved to %s.' ), $uploads [ 'path' ] ));
2005-11-01 22:28:03 +01:00
// Set correct file permissions
2006-11-18 07:09:48 +01:00
$stat = stat ( dirname ( $new_file ));
2006-01-30 23:03:06 +01:00
$perms = $stat [ 'mode' ] & 0000666 ;
2006-11-18 07:09:48 +01:00
@ chmod ( $new_file , $perms );
2005-11-01 22:28:03 +01:00
// Compute the URL
$url = $uploads [ 'url' ] . " / $filename " ;
2007-02-27 16:24:54 +01:00
2006-11-18 07:09:48 +01:00
$return = apply_filters ( 'wp_handle_upload' , array ( 'file' => $new_file , 'url' => $url , 'type' => $type ) );
2005-11-01 22:28:03 +01:00
2006-04-29 11:21:23 +02:00
return $return ;
2005-11-01 22:28:03 +01:00
}
2006-11-18 07:09:48 +01:00
function wp_shrink_dimensions ( $width , $height , $wmax = 128 , $hmax = 96 ) {
2005-11-11 02:27:58 +01:00
if ( $height <= $hmax && $width <= $wmax )
2006-11-18 07:09:48 +01:00
return array ( $width , $height );
2005-11-11 02:27:58 +01:00
elseif ( $width / $height > $wmax / $hmax )
2006-11-18 07:09:48 +01:00
return array ( $wmax , ( int ) ( $height / $width * $wmax ));
2005-11-11 02:27:58 +01:00
else
2006-11-18 07:09:48 +01:00
return array ( ( int ) ( $width / $height * $hmax ), $hmax );
2005-11-11 02:27:58 +01:00
}
2006-11-18 07:09:48 +01:00
function wp_import_cleanup ( $id ) {
wp_delete_attachment ( $id );
2005-11-16 00:39:32 +01:00
}
2006-11-18 07:09:48 +01:00
function wp_import_upload_form ( $action ) {
$size = strtolower ( ini_get ( 'upload_max_filesize' ) );
2006-10-13 09:44:35 +02:00
$bytes = 0 ;
if ( strstr ( $size , 'k' ) )
$bytes = $size * 1024 ;
if ( strstr ( $size , 'm' ) )
$bytes = $size * 1024 * 1024 ;
if ( strstr ( $size , 'g' ) )
$bytes = $size * 1024 * 1024 * 1024 ;
2005-11-16 00:39:32 +01:00
?>
2006-07-05 22:18:56 +02:00
< form enctype = " multipart/form-data " id = " import-upload-form " method = " post " action = " <?php echo $action ?> " >
2006-05-10 22:35:10 +02:00
< p >
2006-11-18 07:09:48 +01:00
< label for = " upload " >< ? php _e ( 'Choose a file from your computer:' ); ?> </label> (<?php printf( __('Maximum size: %s' ), $size ); ?> )
2006-10-13 09:44:35 +02:00
< input type = " file " id = " upload " name = " import " size = " 25 " />
2005-11-16 00:39:32 +01:00
< input type = " hidden " name = " action " value = " save " />
2006-10-13 09:44:35 +02:00
< input type = " hidden " name = " max_file_size " value = " <?php echo $bytes ; ?> " />
2006-05-10 22:35:10 +02:00
</ p >
< p class = " submit " >
2006-11-18 07:09:48 +01:00
< input type = " submit " value = " <?php _e( 'Upload file and import' ); ?> » " />
2006-05-10 22:35:10 +02:00
</ p >
2005-11-16 00:39:32 +01:00
</ form >
2006-02-12 08:53:23 +01:00
< ? php
2005-11-16 00:39:32 +01:00
}
function wp_import_handle_upload () {
2006-11-18 07:09:48 +01:00
$overrides = array ( 'test_form' => false , 'test_type' => false );
$file = wp_handle_upload ( $_FILES [ 'import' ], $overrides );
2005-11-16 00:39:32 +01:00
2006-11-18 07:09:48 +01:00
if ( isset ( $file [ 'error' ] ) )
2005-11-16 00:39:32 +01:00
return $file ;
$url = $file [ 'url' ];
2006-11-30 02:56:06 +01:00
$type = $file [ 'type' ];
2006-05-10 22:35:10 +02:00
$file = addslashes ( $file [ 'file' ] );
2006-11-18 07:09:48 +01:00
$filename = basename ( $file );
2005-11-16 00:39:32 +01:00
// Construct the object array
2006-11-18 07:09:48 +01:00
$object = array ( 'post_title' => $filename ,
2005-11-16 00:39:32 +01:00
'post_content' => $url ,
2006-11-30 02:56:06 +01:00
'post_mime_type' => $type ,
2005-11-16 00:39:32 +01:00
'guid' => $url
);
// Save the data
2006-11-18 07:09:48 +01:00
$id = wp_insert_attachment ( $object , $file );
2005-11-16 00:39:32 +01:00
2006-11-18 07:09:48 +01:00
return array ( 'file' => $file , 'id' => $id );
2005-11-16 00:39:32 +01:00
}
2006-11-18 07:09:48 +01:00
function the_attachment_links ( $id = false ) {
2005-12-13 20:19:56 +01:00
$id = ( int ) $id ;
2006-11-18 07:09:48 +01:00
$post = & get_post ( $id );
2005-12-13 20:19:56 +01:00
2006-02-09 11:03:48 +01:00
if ( $post -> post_type != 'attachment' )
2005-12-13 20:19:56 +01:00
return false ;
2006-11-18 07:09:48 +01:00
$icon = get_attachment_icon ( $post -> ID );
2006-12-05 23:37:19 +01:00
$attachment_data = wp_get_attachment_metadata ( $id );
2006-11-18 07:09:48 +01:00
$thumb = isset ( $attachment_data [ 'thumb' ] );
2005-12-13 20:19:56 +01:00
?>
2006-10-03 09:15:13 +02:00
< form id = " the-attachment-links " >
< table >
2006-10-07 20:31:39 +02:00
< col />
< col class = " widefat " />
2006-10-03 09:15:13 +02:00
< tr >
2006-11-18 07:09:48 +01:00
< th scope = " row " >< ? php _e ( 'URL' ) ?> </th>
2007-01-02 20:28:30 +01:00
< td >< textarea rows = " 1 " cols = " 40 " type = " text " class = " attachmentlinks " readonly = " readonly " >< ? php echo wp_get_attachment_url (); ?> </textarea></td>
2006-10-03 09:15:13 +02:00
</ tr >
2005-12-13 20:19:56 +01:00
< ? php if ( $icon ) : ?>
2006-10-03 09:15:13 +02:00
< tr >
2006-11-18 07:09:48 +01:00
< th scope = " row " >< ? php $thumb ? _e ( 'Thumbnail linked to file' ) : _e ( 'Image linked to file' ); ?> </th>
2007-01-02 20:28:30 +01:00
< td >< textarea rows = " 1 " cols = " 40 " type = " text " class = " attachmentlinks " readonly = " readonly " >< a href = " <?php echo wp_get_attachment_url(); ?> " >< ? php echo $icon ?> </a></textarea></td>
2006-10-03 09:15:13 +02:00
</ tr >
< tr >
2006-12-05 03:29:45 +01:00
< th scope = " row " >< ? php $thumb ? _e ( 'Thumbnail linked to page' ) : _e ( 'Image linked to page' ); ?> </th>
2006-11-18 07:09:48 +01:00
< td >< textarea rows = " 1 " cols = " 40 " type = " text " class = " attachmentlinks " readonly = " readonly " >< a href = " <?php echo get_attachment_link( $post->ID ) ?> " rel = " attachment wp-att-<?php echo $post->ID ; ?> " >< ? php echo $icon ?> </a></textarea></td>
2006-10-03 09:15:13 +02:00
</ tr >
2006-10-07 20:31:39 +02:00
< ? php else : ?>
< tr >
2006-11-18 07:09:48 +01:00
< th scope = " row " >< ? php _e ( 'Link to file' ) ?> </th>
2007-01-02 20:28:30 +01:00
< td >< textarea rows = " 1 " cols = " 40 " type = " text " class = " attachmentlinks " readonly = " readonly " >< a href = " <?php echo wp_get_attachment_url(); ?> " class = " attachmentlink " >< ? php echo basename ( wp_get_attachment_url () ); ?> </a></textarea></td>
2006-10-07 20:31:39 +02:00
</ tr >
< tr >
2006-11-18 07:09:48 +01:00
< th scope = " row " >< ? php _e ( 'Link to page' ) ?> </th>
< td >< textarea rows = " 1 " cols = " 40 " type = " text " class = " attachmentlinks " readonly = " readonly " >< a href = " <?php echo get_attachment_link( $post->ID ) ?> " rel = " attachment wp-att-<?php echo $post->ID ?> " >< ? php the_title (); ?> </a></textarea></td>
2006-10-07 20:31:39 +02:00
</ tr >
2005-12-13 20:19:56 +01:00
< ? php endif ; ?>
2006-10-03 09:15:13 +02:00
</ table >
</ form >
2005-12-13 20:19:56 +01:00
< ? php
}
2006-11-18 07:09:48 +01:00
function get_udims ( $width , $height ) {
2005-12-13 20:19:56 +01:00
if ( $height <= 96 && $width <= 128 )
2006-11-18 07:09:48 +01:00
return array ( $width , $height );
2005-12-13 20:19:56 +01:00
elseif ( $width / $height > 4 / 3 )
2006-11-18 07:09:48 +01:00
return array ( 128 , ( int ) ( $height / $width * 128 ));
2005-12-13 20:19:56 +01:00
else
2006-11-18 07:09:48 +01:00
return array ( ( int ) ( $width / $height * 96 ), 96 );
2005-12-13 20:19:56 +01:00
}
2006-11-18 07:09:48 +01:00
function wp_reset_vars ( $vars ) {
for ( $i = 0 ; $i < count ( $vars ); $i += 1 ) {
2006-07-03 21:03:37 +02:00
$var = $vars [ $i ];
global $$var ;
2006-11-18 07:09:48 +01:00
if ( ! isset ( $$var ) ) {
if ( empty ( $_POST [ " $var " ] ) ) {
if ( empty ( $_GET [ " $var " ] ) )
2006-07-05 05:59:40 +02:00
$$var = '' ;
else
$$var = $_GET [ " $var " ];
2006-07-03 21:03:37 +02:00
} else {
2006-07-05 05:59:40 +02:00
$$var = $_POST [ " $var " ];
2006-07-03 21:03:37 +02:00
}
}
}
}
2006-11-30 09:48:56 +01:00
function wp_remember_old_slug () {
global $post ;
2006-12-21 11:10:04 +01:00
$name = attribute_escape ( $post -> post_name ); // just in case
2006-11-30 09:48:56 +01:00
if ( strlen ( $name ) )
echo '<input type="hidden" id="wp-old-slug" name="wp-old-slug" value="' . $name . '" />' ;
}
2006-09-08 23:42:05 +02:00
// If siteurl or home changed, reset cookies and flush rewrite rules.
2006-11-18 07:09:48 +01:00
function update_home_siteurl ( $old_value , $value ) {
2006-09-08 23:42:05 +02:00
global $wp_rewrite , $user_login , $user_pass_md5 ;
2006-09-23 08:02:45 +02:00
2006-11-18 07:09:48 +01:00
if ( defined ( " WP_INSTALLING " ) )
2006-09-23 08:02:45 +02:00
return ;
2006-09-08 23:42:05 +02:00
// If home changed, write rewrite rules to new location.
$wp_rewrite -> flush_rules ();
// Clear cookies for old paths.
wp_clearcookie ();
// Set cookies for new paths.
2007-02-27 16:24:54 +01:00
wp_setcookie ( $user_login , $user_pass_md5 , true , get_option ( 'home' ), get_option ( 'siteurl' ));
2006-09-08 23:42:05 +02:00
}
2006-11-18 07:09:48 +01:00
add_action ( 'update_option_home' , 'update_home_siteurl' , 10 , 2 );
add_action ( 'update_option_siteurl' , 'update_home_siteurl' , 10 , 2 );
2006-09-08 23:42:05 +02:00
2006-11-18 07:09:48 +01:00
function wp_crop_image ( $src_file , $src_x , $src_y , $src_w , $src_h , $dst_w , $dst_h , $src_abs = false , $dst_file = false ) {
if ( ctype_digit ( $src_file ) ) // Handle int as attachment ID
$src_file = get_attached_file ( $src_file );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
$src = wp_load_image ( $src_file );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
if ( ! is_resource ( $src ))
2006-10-16 08:06:18 +02:00
return $src ;
2006-11-18 07:09:48 +01:00
$dst = imagecreatetruecolor ( $dst_w , $dst_h );
2006-10-16 08:06:18 +02:00
if ( $src_abs ) {
$src_w -= $src_x ;
$src_h -= $src_y ;
}
2006-11-18 07:09:48 +01:00
imageantialias ( $dst , true );
imagecopyresampled ( $dst , $src , 0 , 0 , $src_x , $src_y , $dst_w , $dst_h , $src_w , $src_h );
2006-10-16 08:06:18 +02:00
if ( ! $dst_file )
2006-11-18 07:09:48 +01:00
$dst_file = str_replace ( basename ( $src_file ), 'cropped-' . basename ( $src_file ), $src_file );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
$dst_file = preg_replace ( '/\\.[^\\.]+$/' , '.jpg' , $dst_file );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
if ( imagejpeg ( $dst , $dst_file ) )
2006-10-16 08:06:18 +02:00
return $dst_file ;
else
return false ;
}
2006-11-18 07:09:48 +01:00
function wp_load_image ( $file ) {
if ( ctype_digit ( $file ) )
$file = get_attached_file ( $file );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
if ( ! file_exists ( $file ) )
2006-12-12 09:36:16 +01:00
return sprintf ( __ ( " File '%s' doesn't exist? " ), $file );
if ( ! function_exists ( 'imagecreatefromstring' ) )
return __ ( 'The GD image library is not installed.' );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
$contents = file_get_contents ( $file );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
$image = imagecreatefromstring ( $contents );
2006-10-16 08:06:18 +02:00
2006-11-18 07:09:48 +01:00
if ( ! is_resource ( $image ) )
2006-12-12 09:36:16 +01:00
return sprintf ( __ ( " File '%s' is not an image. " ), $file );
2006-10-16 08:06:18 +02:00
return $image ;
}
2006-12-12 09:36:16 +01:00
function wp_generate_attachment_metadata ( $attachment_id , $file ) {
$attachment = get_post ( $attachment_id );
$metadata = array ();
if ( preg_match ( '!^image/!' , get_post_mime_type ( $attachment )) ) {
$imagesize = getimagesize ( $file );
$metadata [ 'width' ] = $imagesize [ '0' ];
$metadata [ 'height' ] = $imagesize [ '1' ];
list ( $uwidth , $uheight ) = get_udims ( $metadata [ 'width' ], $metadata [ 'height' ]);
$metadata [ 'hwstring_small' ] = " height=' $uheight ' width=' $uwidth ' " ;
$metadata [ 'file' ] = $file ;
2007-01-16 19:34:31 +01:00
$max = apply_filters ( 'wp_thumbnail_creation_size_limit' , 3 * 1024 * 1024 , $attachment_id , $file );
2007-01-17 07:23:18 +01:00
if ( $max < 0 || $metadata [ 'width' ] * $metadata [ 'height' ] < $max ) {
2007-01-16 19:34:31 +01:00
$max_side = apply_filters ( 'wp_thumbnail_max_side_length' , 128 , $attachment_id , $file );
$thumb = wp_create_thumbnail ( $file , $max_side );
2006-12-12 09:36:16 +01:00
if ( @ file_exists ( $thumb ) )
$metadata [ 'thumb' ] = basename ( $thumb );
}
}
return apply_filters ( 'wp_generate_attachment_metadata' , $metadata );
}
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 ) {
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
}
elseif ( ! function_exists ( 'imagejpeg' ) && $type [ 2 ] == 2 ) {
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
}
elseif ( ! function_exists ( 'imagepng' ) && $type [ 2 ] == 3 ) {
$error = __ ( 'Filetype not supported. Thumbnail not created.' );
} 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 );
@ imagecopyresampled ( $thumbnail , $image , 0 , 0 , 0 , 0 , $image_new_width , $image_new_height , $image_attr [ 0 ], $image_attr [ 1 ] );
// If no filters change the filename, we'll do a default transformation.
if ( basename ( $file ) == $thumb = apply_filters ( 'thumbnail_filename' , basename ( $file ) ) )
$thumb = preg_replace ( '!(\.[^.]+)?$!' , __ ( '.thumbnail' ) . '$1' , basename ( $file ), 1 );
$thumbpath = str_replace ( basename ( $file ), $thumb , $file );
2007-01-24 08:17:14 +01:00
// move the thumbnail to its final destination
2006-12-12 09:36:16 +01:00
if ( $type [ 2 ] == 1 ) {
if ( ! imagegif ( $thumbnail , $thumbpath ) ) {
$error = __ ( " Thumbnail path invalid " );
}
}
elseif ( $type [ 2 ] == 2 ) {
if ( ! imagejpeg ( $thumbnail , $thumbpath ) ) {
$error = __ ( " Thumbnail path invalid " );
}
}
elseif ( $type [ 2 ] == 3 ) {
if ( ! imagepng ( $thumbnail , $thumbpath ) ) {
$error = __ ( " Thumbnail path invalid " );
}
}
}
} else {
$error = __ ( 'File not found' );
}
if ( ! empty ( $error ) ) {
return $error ;
} else {
2007-01-24 08:17:14 +01:00
return apply_filters ( 'wp_create_thumbnail' , $thumbpath );
2006-12-12 09:36:16 +01:00
}
}
2006-10-19 02:37:10 +02:00
?>