2004-01-27 10:33:19 +01:00
< ? php
2005-06-19 04:51:48 +02:00
// Creates a new post from the "Write Post" form using $_POST information.
2005-06-18 21:08:38 +02:00
function write_post () {
global $user_ID ;
2005-09-18 21:44:14 +02:00
if ( ! current_user_can ( 'edit_posts' ))
die ( __ ( 'You are not allowed to create posts or drafts on this blog.' ));
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
2005-09-18 21:44:14 +02:00
if ( ! empty ( $_POST [ 'post_author_override' ])) {
2005-10-01 00:45:06 +02:00
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author_override' ];
2005-09-18 21:44:14 +02:00
} else
if ( ! empty ( $_POST [ 'post_author' ])) {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author' ];
} else {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'user_ID' ];
}
if (( $_POST [ 'post_author' ] != $_POST [ 'user_ID' ]) && ! current_user_can ( 'edit_others_posts' ))
die ( __ ( 'You cannot post as this user.' ));
2005-06-18 21:08:38 +02:00
// What to do based on which button they pressed
2005-09-18 21:44:14 +02:00
if ( '' != $_POST [ 'saveasdraft' ])
$_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'saveasprivate' ])
$_POST [ 'post_status' ] = 'private' ;
if ( '' != $_POST [ 'publish' ])
$_POST [ 'post_status' ] = 'publish' ;
if ( '' != $_POST [ 'advanced' ])
$_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'savepage' ])
$_POST [ 'post_status' ] = 'static' ;
2005-07-17 23:08:47 +02:00
2005-09-18 21:44:14 +02:00
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'publish_posts' ))
2005-07-17 23:08:47 +02:00
$_POST [ 'post_status' ] = 'draft' ;
2005-09-18 21:44:14 +02:00
if ( ! empty ( $_POST [ 'edit_date' ])) {
2005-06-18 21:08:38 +02:00
$aa = $_POST [ 'aa' ];
$mm = $_POST [ 'mm' ];
$jj = $_POST [ 'jj' ];
$hh = $_POST [ 'hh' ];
$mn = $_POST [ 'mn' ];
$ss = $_POST [ 'ss' ];
$jj = ( $jj > 31 ) ? 31 : $jj ;
2005-09-18 21:44:14 +02:00
$hh = ( $hh > 23 ) ? $hh - 24 : $hh ;
$mn = ( $mn > 59 ) ? $mn - 60 : $mn ;
$ss = ( $ss > 59 ) ? $ss - 60 : $ss ;
2005-06-18 21:08:38 +02:00
$_POST [ 'post_date' ] = " $aa - $mm - $jj $hh : $mn : $ss " ;
$_POST [ 'post_date_gmt' ] = get_gmt_from_date ( " $aa - $mm - $jj $hh : $mn : $ss " );
2005-09-18 21:44:14 +02:00
}
2005-06-18 21:08:38 +02:00
// Create the post.
$post_ID = wp_insert_post ( $_POST );
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
2005-09-27 01:55:36 +02:00
if ( $_POST [ 'temp_ID' ] )
relocate_children ( $_POST [ 'temp_ID' ], $post_ID );
2005-11-18 10:25:47 +01:00
// Now that we have an ID we can fix any attachment anchor hrefs
fix_attachment_links ( $post_ID );
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
function relocate_children ( $old_ID , $new_ID ) {
global $wpdb ;
2005-09-27 05:42:17 +02:00
$old_ID = ( int ) $old_ID ;
$new_ID = ( int ) $new_ID ;
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.
function fix_attachment_links ( $post_ID ) {
global $wp_rewrite ;
// Relevance check.
if ( false == $wp_rewrite -> using_permalinks () )
return ;
$post = & get_post ( $post_ID );
$search = " #<a[^>]+rel=('| \" )[^' \" ]*attachment[^>]*>#ie " ;
// See if we have any rel="attachment" links
if ( 0 == preg_match_all ( $search , $post -> post_content , $anchor_matches , PREG_PATTERN_ORDER ) )
return ;
$i = 0 ;
$search = " # id=( \" |)( \ d+) \\ 1#i " ;
foreach ( $anchor_matches [ 0 ] as $anchor ) {
echo " $search\n $anchor\n " ;
if ( 0 == preg_match ( $search , $anchor , $id_matches ) )
continue ;
$id = $id_matches [ 2 ];
$post_search [ $i ] = $anchor ;
$post_replace [ $i ] = preg_replace ( " #href=( \" |')[^' \" ]* \\ 1#e " , " stripslashes('href= \\ 1').get_attachment_link( $id ).stripslashes(' \\ 1') " , $anchor );
++ $i ;
}
$post -> post_content = str_replace ( $post_search , $post_replace , $post -> post_content );
return wp_update_post ( $post );
}
2005-06-19 04:51:48 +02:00
// Update an existing post with values provided in $_POST.
2005-06-19 03:33:38 +02:00
function edit_post () {
global $user_ID ;
2005-06-26 21:55:12 +02:00
$post_ID = ( int ) $_POST [ 'post_ID' ];
2005-06-19 03:33:38 +02:00
2005-09-18 21:44:14 +02:00
if ( ! current_user_can ( 'edit_post' , $post_ID ))
die ( __ ( 'You are not allowed to edit this post.' ));
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' ];
2005-09-18 21:44:14 +02: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
if ( ! empty ( $_POST [ 'post_author' ])) {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'post_author' ];
} else {
$_POST [ 'post_author' ] = ( int ) $_POST [ 'user_ID' ];
}
2005-06-19 03:33:38 +02:00
2005-09-18 21:44:14 +02:00
if (( $_POST [ 'post_author' ] != $_POST [ 'user_ID' ]) && ! current_user_can ( 'edit_others_posts' ))
die ( __ ( 'You cannot post as this user.' ));
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
2005-09-18 21:44:14 +02:00
if ( '' != $_POST [ 'saveasdraft' ])
$_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'saveasprivate' ])
$_POST [ 'post_status' ] = 'private' ;
if ( '' != $_POST [ 'publish' ])
$_POST [ 'post_status' ] = 'publish' ;
if ( '' != $_POST [ 'advanced' ])
$_POST [ 'post_status' ] = 'draft' ;
if ( '' != $_POST [ 'savepage' ])
$_POST [ 'post_status' ] = 'static' ;
2005-07-17 23:08:47 +02:00
2005-09-18 21:44:14 +02:00
if ( 'publish' == $_POST [ 'post_status' ] && ! current_user_can ( 'publish_posts' ))
2005-07-17 23:08:47 +02:00
$_POST [ 'post_status' ] = 'draft' ;
2005-09-18 21:44:14 +02:00
if ( ! isset ( $_POST [ 'comment_status' ]))
2005-08-05 22:44:18 +02:00
$_POST [ 'comment_status' ] = 'closed' ;
2005-09-18 21:44:14 +02: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
if ( ! empty ( $_POST [ 'edit_date' ])) {
2005-06-19 03:33:38 +02:00
$aa = $_POST [ 'aa' ];
$mm = $_POST [ 'mm' ];
$jj = $_POST [ 'jj' ];
$hh = $_POST [ 'hh' ];
$mn = $_POST [ 'mn' ];
$ss = $_POST [ 'ss' ];
$jj = ( $jj > 31 ) ? 31 : $jj ;
2005-09-18 21:44:14 +02:00
$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 " ;
$_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
wp_update_post ( $_POST );
2005-11-18 10:25:47 +01:00
// Now that we have an ID we can fix any attachment anchor hrefs
fix_attachment_links ( $_POST [ 'ID' ]);
2005-06-19 03:33:38 +02:00
// Meta Stuff
2005-09-18 21:44:14 +02:00
if ( $_POST [ 'meta' ])
: foreach ( $_POST [ 'meta' ] as $key => $value )
: update_meta ( $key , $value [ 'key' ], $value [ 'value' ]);
endforeach ;
2005-06-19 03:33:38 +02:00
endif ;
2005-09-18 21:44:14 +02:00
if ( $_POST [ 'deletemeta' ])
: foreach ( $_POST [ 'deletemeta' ] as $key => $value )
: delete_meta ( $key );
endforeach ;
2005-06-19 03:33:38 +02:00
endif ;
add_meta ( $post_ID );
2005-09-18 21:44:14 +02: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' ];
2005-09-18 21:44:14 +02:00
if ( ! current_user_can ( 'edit_post' , $comment_post_ID ))
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
if ( ! empty ( $_POST [ 'edit_date' ])) {
2005-06-26 21:55:12 +02:00
$aa = $_POST [ 'aa' ];
$mm = $_POST [ 'mm' ];
$jj = $_POST [ 'jj' ];
$hh = $_POST [ 'hh' ];
$mn = $_POST [ 'mn' ];
$ss = $_POST [ 'ss' ];
$jj = ( $jj > 31 ) ? 31 : $jj ;
2005-09-18 21:44:14 +02:00
$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 " ;
}
wp_update_comment ( $_POST );
}
2005-06-19 04:51:48 +02:00
// Get an existing post and format it for editing.
function get_post_to_edit ( $id ) {
$post = get_post ( $id );
$post -> post_content = format_to_edit ( $post -> post_content );
$post -> post_content = apply_filters ( 'content_edit_pre' , $post -> post_content );
$post -> post_excerpt = format_to_edit ( $post -> post_excerpt );
$post -> post_excerpt = apply_filters ( 'excerpt_edit_pre' , $post -> post_excerpt );
$post -> post_title = format_to_edit ( $post -> post_title );
$post -> post_title = apply_filters ( 'title_edit_pre' , $post -> post_title );
if ( $post -> post_status == 'static' )
2005-09-18 21:44:14 +02:00
$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 () {
2005-11-17 04:26:24 +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 );
} else {
$post_title = '' ;
}
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 );
$popupurl = wp_specialchars ( $_REQUEST [ 'popupurl' ]);
$post_content = '<a href="' . $popupurl . '">' . $post_title . '</a>' . " \n $text " ;
}
if ( ! empty ( $_REQUEST [ 'excerpt' ]) )
$post_excerpt = wp_specialchars ( stripslashes ( $_REQUEST [ 'excerpt' ]));
else
$post_excerpt = '' ;
2005-06-19 04:51:48 +02:00
$post -> post_status = 'draft' ;
$post -> comment_status = get_settings ( 'default_comment_status' );
$post -> ping_status = get_settings ( 'default_ping_status' );
$post -> post_pingback = get_settings ( 'default_pingback_flag' );
$post -> post_category = get_settings ( 'default_category' );
2005-11-17 04:26:24 +01:00
$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 ;
}
2005-06-26 21:55:12 +02:00
function get_comment_to_edit ( $id ) {
$comment = get_comment ( $id );
$comment -> comment_content = format_to_edit ( $comment -> comment_content );
$comment -> comment_content = apply_filters ( 'comment_edit_pre' , $comment -> comment_content );
$comment -> comment_author = format_to_edit ( $comment -> comment_author );
$comment -> comment_author_email = format_to_edit ( $comment -> comment_author_email );
$comment -> comment_author_url = format_to_edit ( $comment -> comment_author_url );
return $comment ;
}
2005-07-03 21:26:51 +02:00
function get_category_to_edit ( $id ) {
$category = get_category ( $id );
return $category ;
}
2005-09-14 02:03:02 +02:00
// Creates a new user from the "Users" form using $_POST information.
function add_user () {
2005-09-18 21:44:14 +02:00
return edit_user ();
2005-09-14 02:03:02 +02:00
}
2005-09-18 21:44:14 +02:00
function edit_user ( $user_id = 0 ) {
2005-11-06 04:58:52 +01:00
global $current_user , $wp_roles ;
2005-09-18 21:44:14 +02:00
if ( $user_id != 0 ) {
2005-09-14 02:03:02 +02:00
$update = true ;
$user -> ID = $user_id ;
$userdata = get_userdata ( $user_id );
$user -> user_login = $userdata -> user_login ;
} else {
$update = false ;
$user = '' ;
}
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'user_login' ]))
2005-09-14 02:03:02 +02:00
$user -> user_login = wp_specialchars ( trim ( $_POST [ 'user_login' ]));
$pass1 = $pass2 = '' ;
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'pass1' ]))
2005-09-14 02:03:02 +02:00
$pass1 = $_POST [ 'pass1' ];
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'pass2' ]))
2005-09-14 02:03:02 +02:00
$pass2 = $_POST [ 'pass2' ];
2005-11-06 04:58:52 +01:00
if ( isset ( $_POST [ 'role' ])) {
if ( $user_id != $current_user -> id || $wp_roles -> role_objects [ $_POST [ 'role' ]] -> has_cap ( 'edit_users' ))
$user -> role = $_POST [ 'role' ];
}
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'email' ]))
2005-09-14 02:03:02 +02:00
$user -> user_email = wp_specialchars ( trim ( $_POST [ 'email' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'url' ])) {
2005-09-14 02:03:02 +02:00
$user -> user_url = wp_specialchars ( trim ( $_POST [ 'url' ]));
2005-09-18 21:44:14 +02:00
$user -> user_url = preg_match ( '/^(https?|ftps?|mailto|news|gopher):/is' , $user -> user_url ) ? $user -> user_url : 'http://' . $user -> user_url ;
2005-09-14 02:03:02 +02:00
}
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'first_name' ]))
2005-09-14 02:03:02 +02:00
$user -> first_name = wp_specialchars ( trim ( $_POST [ 'first_name' ]));
2005-11-01 22:28:03 +01:00
if ( isset ( $_POST [ 'middle_name' ]))
$user -> middle_name = wp_specialchars ( trim ( $_POST [ 'middle_name' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'last_name' ]))
2005-09-14 02:03:02 +02:00
$user -> last_name = wp_specialchars ( trim ( $_POST [ 'last_name' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'nickname' ]))
2005-09-14 02:03:02 +02:00
$user -> nickname = wp_specialchars ( trim ( $_POST [ 'nickname' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'display_name' ]))
2005-09-14 02:03:02 +02:00
$user -> display_name = wp_specialchars ( trim ( $_POST [ 'display_name' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'description' ]))
2005-09-14 02:03:02 +02:00
$user -> description = wp_specialchars ( trim ( $_POST [ 'description' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'jabber' ]))
2005-09-14 02:03:02 +02:00
$user -> jabber = wp_specialchars ( trim ( $_POST [ 'jabber' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'aim' ]))
2005-09-14 02:03:02 +02:00
$user -> aim = wp_specialchars ( trim ( $_POST [ 'aim' ]));
2005-09-18 21:44:14 +02:00
if ( isset ( $_POST [ 'yim' ]))
2005-09-14 02:03:02 +02:00
$user -> yim = wp_specialchars ( trim ( $_POST [ 'yim' ]));
2005-11-01 22:28:03 +01:00
if ( isset ( $_POST [ 'flickr_username' ]))
$user -> flickr_username = wp_specialchars ( trim ( $_POST [ 'flickr_username' ]));
2005-09-14 02:03:02 +02:00
2005-09-18 21:44:14 +02:00
$errors = array ();
2005-09-14 02:03:02 +02:00
/* checking that username has been typed */
if ( $user -> user_login == '' )
$errors [ 'user_login' ] = __ ( '<strong>ERROR</strong>: Please enter a username.' );
/* checking the password has been typed twice */
2005-09-18 21:44:14 +02:00
do_action ( 'check_passwords' , array ( $user -> user_login , & $pass1 , & $pass2 ));
if ( ! $update ) {
if ( $pass1 == '' || $pass2 == '' )
2005-09-14 02:03:02 +02:00
$errors [ 'pass' ] = __ ( '<strong>ERROR</strong>: Please enter your password twice.' );
} else {
2005-09-18 21:44:14 +02:00
if (( empty ( $pass1 ) && ! empty ( $pass2 )) || ( empty ( $pass2 ) && ! empty ( $pass1 )))
2005-09-14 02:03:02 +02:00
$errors [ 'pass' ] = __ ( " <strong>ERROR</strong>: you typed your new password only once. " );
}
2005-09-18 21:44:14 +02:00
2005-11-14 10:59:47 +01:00
/* Check for "\" in password */
if ( strpos ( " " . $pass1 , " \\ " ) )
$errors [ 'pass' ] = __ ( '<strong>ERROR</strong>: Passwords may not contain the character "\\".' );
2005-09-14 02:03:02 +02:00
/* checking the password has been typed twice the same */
if ( $pass1 != $pass2 )
$errors [ 'pass' ] = __ ( '<strong>ERROR</strong>: Please type the same password in the two password fields.' );
2005-09-18 21:44:14 +02:00
if ( ! empty ( $pass1 ))
2005-09-14 02:03:02 +02:00
$user -> user_pass = $pass1 ;
2005-09-18 21:44:14 +02:00
if ( ! $update && username_exists ( $user_login ))
2005-09-14 02:03:02 +02:00
$errors [ 'user_login' ] = __ ( '<strong>ERROR</strong>: This username is already registered, please choose another one.' );
/* checking e-mail address */
2005-09-18 21:44:14 +02:00
if ( empty ( $user -> user_email )) {
2005-09-14 02:03:02 +02:00
$errors [ 'user_email' ] = __ ( " <strong>ERROR</strong>: please type an e-mail address " );
2005-09-18 21:44:14 +02:00
} else
if ( ! is_email ( $user -> user_email )) {
$errors [ 'user_email' ] = __ ( " <strong>ERROR</strong>: the email address isn't correct " );
}
2005-09-14 02:03:02 +02:00
2005-09-18 21:44:14 +02:00
if ( count ( $errors ) != 0 )
2005-09-14 02:03:02 +02:00
return $errors ;
2005-09-18 21:44:14 +02:00
if ( $update ) {
2005-09-14 02:03:02 +02:00
$user_id = wp_update_user ( get_object_vars ( $user ));
} else {
$user_id = wp_insert_user ( get_object_vars ( $user ));
wp_new_user_notification ( $user_id );
}
2005-09-18 21:44:14 +02:00
2005-09-14 02:03:02 +02:00
return $errors ;
}
2005-09-18 21:44:14 +02:00
function get_link_to_edit ( $link_id ) {
$link = get_link ( $link_id );
$link -> link_url = wp_specialchars ( $link -> link_url , 1 );
$link -> link_name = wp_specialchars ( $link -> link_name , 1 );
$link -> link_description = wp_specialchars ( $link -> link_description );
$link -> link_notes = wp_specialchars ( $link -> link_notes );
$link -> link_rss = wp_specialchars ( $link -> link_rss );
return $link ;
}
2005-09-19 02:47:58 +02:00
function get_default_link_to_edit () {
if ( isset ( $_GET [ 'linkurl' ]) )
$link -> link_url = wp_specialchars ( $_GET [ 'linkurl' ], 1 );
else
$link -> link_url = '' ;
if ( isset ( $_GET [ 'name' ]) )
$link -> link_name = wp_specialchars ( $_GET [ 'name' ], 1 );
else
$link -> link_name = '' ;
return $link ;
}
2005-09-18 21:44:14 +02:00
function add_link () {
return edit_link ();
}
function edit_link ( $link_id = '' ) {
if ( ! current_user_can ( 'manage_links' ))
die ( __ ( " Cheatin' uh ? " ));
$_POST [ 'link_url' ] = wp_specialchars ( $_POST [ 'link_url' ]);
2005-11-11 02:13:30 +01:00
$_POST [ 'link_url' ] = preg_match ( '/^(https?|ftps?|mailto|news|gopher):/is' , $_POST [ 'link_url' ]) ? $_POST [ 'link_url' ] : 'http://' . $_POST [ 'link_url' ];
2005-09-18 21:44:14 +02: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' ]);
$auto_toggle = get_autotoggle ( $_POST [ 'link_category' ]);
// if we are in an auto toggle category and this one is visible then we
// need to make the others invisible before we add this new one.
// FIXME Add category toggle func.
//if (($auto_toggle == 'Y') && ($link_visible == 'Y')) {
// $wpdb->query("UPDATE $wpdb->links set link_visible = 'N' WHERE link_category = $link_category");
//}
if ( ! empty ( $link_id ) ) {
$_POST [ 'link_id' ] = $link_id ;
return wp_update_link ( $_POST );
} else {
return wp_insert_link ( $_POST );
}
}
function url_shorten ( $url ) {
2004-02-17 09:35:04 +01:00
$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 )
2005-09-18 21:44:14 +02:00
$short_url = substr ( $short_url , 0 , 32 ) . '...' ;
2004-02-17 09:35:04 +01:00
return $short_url ;
}
2004-02-13 10:59:47 +01:00
function selected ( $selected , $current ) {
2005-09-18 21:44:14 +02:00
if ( $selected == $current )
echo ' selected="selected"' ;
2004-02-13 10:59:47 +01:00
}
function checked ( $checked , $current ) {
2005-09-18 21:44:14 +02:00
if ( $checked == $current )
echo ' checked="checked"' ;
2004-02-13 10:59:47 +01:00
}
2005-09-18 21:44:14 +02:00
function return_categories_list ( $parent = 0 ) {
2005-07-23 08:22:48 +02:00
global $wpdb ;
2005-11-06 07:48:41 +01:00
return $wpdb -> get_col ( " SELECT cat_ID FROM $wpdb->categories WHERE category_parent = $parent " );
}
function sort_cats ( $cat1 , $cat2 ) {
return strcasecmp ( $cat1 [ 'cat_name' ], $cat2 [ 'cat_name' ]);
2004-06-16 18:40:40 +02:00
}
function get_nested_categories ( $default = 0 , $parent = 0 ) {
2005-09-18 21:44:14 +02:00
global $post_ID , $mode , $wpdb ;
if ( $post_ID ) {
$checked_categories = $wpdb -> get_col ( "
SELECT category_id
FROM $wpdb -> categories , $wpdb -> post2cat
WHERE $wpdb -> post2cat . category_id = cat_ID AND $wpdb -> post2cat . post_id = '$post_ID'
" );
if ( count ( $checked_categories ) == 0 ) {
// No selected categories, strange
$checked_categories [] = $default ;
}
} else {
$checked_categories [] = $default ;
}
$cats = return_categories_list ( $parent );
$result = array ();
if ( is_array ( $cats )) {
foreach ( $cats as $cat ) {
2005-08-03 02:21:53 +02:00
$result [ $cat ][ 'children' ] = get_nested_categories ( $default , $cat );
$result [ $cat ][ 'cat_ID' ] = $cat ;
$result [ $cat ][ 'checked' ] = in_array ( $cat , $checked_categories );
$result [ $cat ][ 'cat_name' ] = get_the_category_by_ID ( $cat );
}
}
2005-11-06 07:48:41 +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
}
function write_nested_categories ( $categories ) {
2005-09-18 21:44:14 +02:00
foreach ( $categories as $category ) {
echo '<label for="category-' , $category [ 'cat_ID' ], '" class="selectit"><input value="' , $category [ 'cat_ID' ], '" type="checkbox" name="post_category[]" id="category-' , $category [ 'cat_ID' ], '"' , ( $category [ 'checked' ] ? ' checked="checked"' : " " ), '/> ' , wp_specialchars ( $category [ 'cat_name' ]), " </label> \n " ;
2004-02-09 09:55:29 +01:00
2005-09-18 21:44:14 +02:00
if ( isset ( $category [ 'children' ])) {
echo " \n <span class='cat-nest'> \n " ;
write_nested_categories ( $category [ 'children' ]);
echo " </span> \n " ;
}
}
2004-02-09 09:55:29 +01:00
}
function dropdown_categories ( $default = 0 ) {
2005-09-18 21:44:14 +02:00
write_nested_categories ( get_nested_categories ( $default ));
}
2004-01-27 10:33:19 +01:00
// Dandy new recursive multiple category stuff.
2004-02-01 03:00:26 +01:00
function cat_rows ( $parent = 0 , $level = 0 , $categories = 0 ) {
2005-07-15 04:16:45 +02:00
global $wpdb , $class ;
2005-07-09 03:27:46 +02:00
2005-09-18 21:44:14 +02:00
if ( ! $categories )
2004-05-24 10:22:18 +02:00
$categories = $wpdb -> get_results ( " SELECT * FROM $wpdb->categories ORDER BY cat_name " );
2004-11-18 20:51:31 +01:00
2004-01-27 10:33:19 +01:00
if ( $categories ) {
foreach ( $categories as $category ) {
2004-02-01 03:00:26 +01:00
if ( $category -> category_parent == $parent ) {
2004-12-12 21:41:19 +01:00
$category -> cat_name = wp_specialchars ( $category -> cat_name );
2004-05-24 10:22:18 +02:00
$count = $wpdb -> get_var ( " SELECT COUNT(post_id) FROM $wpdb->post2cat WHERE category_id = $category->cat_ID " );
2004-02-01 03:00:26 +01:00
$pad = str_repeat ( '— ' , $level );
2005-11-14 11:11:15 +01:00
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' );
if ( $category -> cat_ID != $default_cat_id )
$edit .= " <td><a href='categories.php?action=delete&cat_ID= $category->cat_ID ' onclick= \" return deleteSomething( 'cat', $category->cat_ID , ' " . sprintf ( __ ( " You are about to delete the category "%s". All of its posts will go to the default category. \\ n"OK" to delete, "Cancel" to stop. " ), wp_specialchars ( $category -> cat_name , 1 )) . " ' ); \" class='delete'> " . __ ( 'Delete' ) . " </a> " ;
else
$edit .= " <td style='text-align:center'> " . __ ( " Default " );
}
2004-11-18 20:51:31 +01:00
else
$edit = '' ;
2005-09-18 21:44:14 +02:00
2004-07-06 20:14:42 +02:00
$class = ( 'alternate' == $class ) ? '' : 'alternate' ;
2005-08-31 04:39:17 +02:00
echo " <tr id='cat- $category->cat_ID ' class=' $class '><th scope='row'> $category->cat_ID </th><td> $pad $category->cat_name </td>
2005-09-18 21:44:14 +02:00
< td > $category -> category_description </ td >
< td > $count </ td >
< td > $edit </ td >
</ tr > " ;
cat_rows ( $category -> cat_ID , $level + 1 , $categories );
2005-01-02 00:05:07 +01:00
}
}
} else {
return false ;
}
}
2005-09-18 21:44:14 +02:00
function page_rows ( $parent = 0 , $level = 0 , $pages = 0 ) {
2005-07-15 04:16:45 +02:00
global $wpdb , $class , $post ;
2005-01-02 00:05:07 +01:00
if ( ! $pages )
$pages = $wpdb -> get_results ( " SELECT * FROM $wpdb->posts WHERE post_status = 'static' ORDER BY menu_order " );
if ( $pages ) {
2005-09-18 21:44:14 +02:00
foreach ( $pages as $post ) {
start_wp ();
2005-01-02 00:05:07 +01:00
if ( $post -> post_parent == $parent ) {
$post -> post_title = wp_specialchars ( $post -> post_title );
$pad = str_repeat ( '— ' , $level );
$id = $post -> ID ;
$class = ( 'alternate' == $class ) ? '' : 'alternate' ;
?>
2005-08-31 04:39:17 +02:00
< tr id = 'page-<?php echo $id; ?>' class = '<?php echo $class; ?>' >
2005-01-02 00:05:07 +01:00
< th scope = " row " >< ? php echo $post -> ID ; ?> </th>
< td >
< ? php echo $pad ; ?> <?php the_title() ?>
</ td >
< td >< ? php the_author () ?> </td>
2005-02-12 10:32:00 +01:00
< td >< ? php echo mysql2date ( 'Y-m-d g:i a' , $post -> post_modified ); ?> </td>
2005-01-02 00:05:07 +01:00
< td >< a href = " <?php the_permalink(); ?> " rel = " permalink " class = " edit " >< ? php _e ( 'View' ); ?> </a></td>
2005-07-14 00:26:26 +02:00
< td >< ? php if ( current_user_can ( 'edit_pages' ) ) { echo " <a href='post.php?action=edit&post= $id ' class='edit'> " . __ ( 'Edit' ) . " </a> " ; } ?> </td>
2005-08-31 04:39:17 +02:00
< td >< ? php if ( current_user_can ( 'edit_pages' ) ) { echo " <a href='post.php?action=delete&post= $id ' class='delete' onclick= \" return deleteSomething( 'page', " . $id . " , ' " . sprintf ( __ ( " You are about to delete the "%s" page. \\ n"OK" to delete, "Cancel" to stop. " ), wp_specialchars ( get_the_title ( '' , '' , 0 ), 1 )) . " ' ); \" > " . __ ( 'Delete' ) . " </a> " ; } ?> </td>
2005-01-02 00:05:07 +01:00
</ tr >
< ? php
2005-09-18 21:44:14 +02:00
page_rows ( $id , $level + 1 , $pages );
2004-02-01 03:00:26 +01:00
}
2004-01-27 10:33:19 +01:00
}
} else {
return false ;
}
}
2004-12-09 01:44:05 +01:00
function wp_dropdown_cats ( $currentcat = 0 , $currentparent = 0 , $parent = 0 , $level = 0 , $categories = 0 ) {
2004-05-24 10:22:18 +02:00
global $wpdb , $bgcolor ;
2004-02-01 03:00:26 +01:00
if ( ! $categories ) {
2004-05-24 10:22:18 +02:00
$categories = $wpdb -> get_results ( " SELECT * FROM $wpdb->categories ORDER BY cat_name " );
2004-02-01 03:00:26 +01:00
}
2004-01-27 10:33:19 +01:00
if ( $categories ) {
2005-09-18 21:44:14 +02:00
foreach ( $categories as $category ) {
if ( $currentcat != $category -> cat_ID && $parent == $category -> category_parent ) {
$count = $wpdb -> get_var ( " SELECT COUNT(post_id) FROM $wpdb->post2cat WHERE category_id = $category->cat_ID " );
$pad = str_repeat ( '– ' , $level );
$category -> cat_name = wp_specialchars ( $category -> cat_name );
echo " \n \t <option value=' $category->cat_ID ' " ;
if ( $currentparent == $category -> cat_ID )
echo " selected='selected' " ;
echo " > $pad $category->cat_name </option> " ;
wp_dropdown_cats ( $currentcat , $currentparent , $category -> cat_ID , $level + 1 , $categories );
}
}
2004-01-27 10:33:19 +01:00
} else {
return false ;
}
}
2005-09-19 02:47:58 +02:00
function link_category_dropdown ( $fieldname , $selected = 0 ) {
global $wpdb ;
$results = $wpdb -> get_results ( " SELECT cat_id, cat_name, auto_toggle FROM $wpdb->linkcategories ORDER BY cat_id " );
echo " \n <select name=' $fieldname ' size='1'> \n " ;
foreach ( $results as $row ) {
echo " \n \t <option value=' $row->cat_id ' " ;
if ( $row -> cat_id == $selected )
echo " selected='selected' " ;
echo " > $row->cat_id : " . wp_specialchars ( $row -> cat_name );
if ( $row -> auto_toggle == 'Y' )
echo ' (auto toggle)' ;
echo " </option> " ;
}
echo " \n </select> \n " ;
}
2004-02-05 15:28:02 +01:00
function wp_create_thumbnail ( $file , $max_side , $effect = '' ) {
2005-09-18 21:44:14 +02:00
// 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 );
}
2004-02-05 15:28:02 +01:00
if ( function_exists ( 'imageantialias' ))
2005-09-18 21:44:14 +02:00
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 ]);
// move the thumbnail to it's final destination
$path = explode ( '/' , $file );
$thumbpath = substr ( $file , 0 , strrpos ( $file , '/' )) . '/thumb-' . $path [ count ( $path ) - 1 ];
if ( $type [ 2 ] == 1 ) {
if ( ! imagegif ( $thumbnail , $thumbpath )) {
$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 " );
}
}
}
2005-10-20 22:48:32 +02:00
} else {
$error = __ ( 'File not found' );
2005-09-18 21:44:14 +02:00
}
if ( ! empty ( $error )) {
return $error ;
} else {
return 1 ;
}
2004-02-05 15:28:02 +01:00
}
2004-03-23 19:02:05 +01:00
// Some postmeta stuff
function has_meta ( $postid ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-03-23 19:02:05 +01:00
return $wpdb -> get_results ( "
2005-09-18 21:44:14 +02:00
SELECT meta_key , meta_value , meta_id , post_id
FROM $wpdb -> postmeta
WHERE post_id = '$postid'
ORDER BY meta_key , meta_id " , ARRAY_A);
2004-03-23 19:02:05 +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
2005-09-18 21:44:14 +02:00
if ( ! $meta )
return ;
2004-12-09 05:12:20 +01:00
$count = 0 ;
2004-04-28 04:23:46 +02:00
?>
2004-04-28 21:49:27 +02:00
< table id = 'meta-list' cellpadding = " 3 " >
2004-04-28 04:23:46 +02:00
< tr >
< th >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
< th colspan = '2' >< ? php _e ( 'Action' ) ?> </th>
</ tr >
< ? php
2005-09-18 21:44:14 +02:00
2004-03-23 19:02:05 +01:00
foreach ( $meta as $entry ) {
2005-09-18 21:44:14 +02:00
++ $count ;
if ( $count % 2 )
$style = 'alternate' ;
else
$style = '' ;
if ( '_' == $entry [ 'meta_key' ] { 0 })
$style .= ' hidden' ;
2004-04-28 04:23:46 +02:00
echo "
2005-09-18 21:44:14 +02:00
< tr class = '$style' >
< td valign = 'top' >< input name = 'meta[{$entry[' meta_id ']}][key]' tabindex = '6' type = 'text' size = '20' value = '{$entry[' meta_key ']}' /></ td >
< td >< textarea name = 'meta[{$entry[' meta_id ']}][value]' tabindex = '6' rows = '2' cols = '30' > { $entry [ 'meta_value' ]} </ textarea ></ td >
< td align = 'center' width = '10%' >< input name = 'updatemeta' type = 'submit' class = 'updatemeta' tabindex = '6' value = '".__(' Update ')."' /></ td >
< td align = 'center' width = '10%' >< input name = 'deletemeta[{$entry[' meta_id ']}]' type = 'submit' class = 'deletemeta' tabindex = '6' value = '".__(' Delete ')."' /></ td >
</ tr >
" ;
2004-03-23 19:02:05 +01:00
}
2004-04-28 04:23:46 +02:00
echo "
2005-09-18 21:44:14 +02:00
</ table >
" ;
2004-03-23 19:02:05 +01:00
}
// Get a list of previously defined keys
function get_meta_keys () {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2005-09-18 21:44:14 +02:00
2004-03-23 19:02:05 +01:00
$keys = $wpdb -> get_col ( "
2005-09-18 21:44:14 +02:00
SELECT meta_key
FROM $wpdb -> postmeta
GROUP BY meta_key
ORDER BY meta_key " );
2004-03-23 19:02:05 +01:00
return $keys ;
}
function meta_form () {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-04-28 06:49:16 +02:00
$keys = $wpdb -> get_col ( "
2005-09-18 21:44:14 +02:00
SELECT meta_key
FROM $wpdb -> postmeta
GROUP BY meta_key
ORDER BY meta_id DESC
LIMIT 10 " );
2004-03-23 19:02:05 +01:00
?>
2005-08-27 20:42:41 +02:00
< h3 >< ? php _e ( 'Add a new custom field:' ) ?> </h3>
2004-04-28 21:49:27 +02:00
< table cellspacing = " 3 " cellpadding = " 3 " >
2004-04-28 04:23:46 +02:00
< tr >
< th colspan = " 2 " >< ? php _e ( 'Key' ) ?> </th>
< th >< ? php _e ( 'Value' ) ?> </th>
</ tr >
< tr valign = " top " >
2004-05-20 13:32:14 +02:00
< td align = " right " width = " 18% " >
< ? php if ( $keys ) : ?>
< select id = " metakeyselect " name = " metakeyselect " tabindex = " 7 " >
2004-12-04 07:53:10 +01:00
< option value = " #NONE# " >< ? php _e ( '- Select -' ); ?> </option>
2004-03-23 19:02:05 +01:00
< ? php
2005-09-18 21:44:14 +02:00
foreach ( $keys as $key ) {
2004-04-28 04:23:46 +02:00
echo " \n \t <option value=' $key '> $key </option> " ;
2004-03-23 19:02:05 +01:00
}
?>
2004-12-04 07:53:10 +01:00
</ select > < ? php _e ( 'or' ); ?>
2004-05-20 13:32:14 +02:00
< ? php endif ; ?>
</ td >
2004-04-28 21:49:27 +02:00
< td >< input type = " text " id = " metakeyinput " name = " metakeyinput " tabindex = " 7 " /></ td >
2004-12-09 05:12:20 +01:00
< td >< textarea id = " metavalue " name = " metavalue " rows = " 3 " cols = " 25 " tabindex = " 8 " ></ textarea ></ td >
2004-04-28 04:23:46 +02:00
</ tr >
2004-03-23 19:02:05 +01:00
2004-04-28 04:23:46 +02:00
</ table >
2004-12-09 05:12:20 +01:00
< p class = " submit " >< input type = " submit " name = " updatemeta " tabindex = " 9 " value = " <?php _e('Add Custom Field »') ?> " /></ p >
2004-03-23 19:02:05 +01:00
< ? php
2005-09-18 21:44:14 +02:00
2004-03-23 19:02:05 +01:00
}
function add_meta ( $post_ID ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-03-23 19:02:05 +01:00
2005-09-18 21:44:14 +02:00
$metakeyselect = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metakeyselect' ])));
$metakeyinput = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metakeyinput' ])));
$metavalue = $wpdb -> escape ( stripslashes ( trim ( $_POST [ 'metavalue' ])));
if ( ! empty ( $metavalue ) && ((( '#NONE#' != $metakeyselect ) && ! empty ( $metakeyselect )) || ! empty ( $metakeyinput ))) {
2004-03-23 19:02:05 +01:00
// We have a key/value pair. If both the select and the
// input for the key have data, the input takes precedence:
if ( '#NONE#' != $metakeyselect )
$metakey = $metakeyselect ;
2005-09-18 21:44:14 +02:00
2004-03-23 19:02:05 +01:00
if ( $metakeyinput )
$metakey = $metakeyinput ; // default
$result = $wpdb -> query ( "
2005-09-18 21:44:14 +02:00
INSERT INTO $wpdb -> postmeta
( post_id , meta_key , meta_value )
VALUES ( '$post_ID' , '$metakey' , '$metavalue' )
" );
2004-03-23 19:02:05 +01:00
}
} // add_meta
2004-04-28 06:49:16 +02:00
function delete_meta ( $mid ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-04-28 04:23:46 +02:00
2004-05-24 10:22:18 +02:00
$result = $wpdb -> query ( " DELETE FROM $wpdb->postmeta WHERE meta_id = ' $mid ' " );
2004-03-23 19:02:05 +01:00
}
2004-04-28 06:49:16 +02:00
function update_meta ( $mid , $mkey , $mvalue ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-04-28 06:49:16 +02:00
2004-05-24 10:22:18 +02:00
return $wpdb -> query ( " UPDATE $wpdb->postmeta SET meta_key = ' $mkey ', meta_value = ' $mvalue ' WHERE meta_id = ' $mid ' " );
2004-04-28 06:49:16 +02:00
}
2005-03-10 10:50:26 +01:00
function touch_time ( $edit = 1 , $for_post = 1 ) {
2005-07-17 21:02:05 +02:00
global $month , $post , $comment ;
2004-04-30 10:56:49 +02:00
2005-11-14 10:56:41 +01:00
if ( $for_post )
$edit = ( ( 'draft' == $post -> post_status ) && ( ! $post -> post_date || '0000-00-00 00:00:00' == $post -> post_date ) ) ? false : true ;
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
2004-04-30 10:56:49 +02:00
$time_adj = time () + ( get_settings ( 'gmt_offset' ) * 3600 );
2005-07-17 21:02:05 +02:00
$post_date = ( $for_post ) ? $post -> post_date : $comment -> comment_date ;
2004-04-30 10:56:49 +02:00
$jj = ( $edit ) ? mysql2date ( 'd' , $post_date ) : gmdate ( 'd' , $time_adj );
$mm = ( $edit ) ? mysql2date ( 'm' , $post_date ) : gmdate ( 'm' , $time_adj );
$aa = ( $edit ) ? mysql2date ( 'Y' , $post_date ) : gmdate ( 'Y' , $time_adj );
$hh = ( $edit ) ? mysql2date ( 'H' , $post_date ) : gmdate ( 'H' , $time_adj );
$mn = ( $edit ) ? mysql2date ( 'i' , $post_date ) : gmdate ( 'i' , $time_adj );
$ss = ( $edit ) ? mysql2date ( 's' , $post_date ) : gmdate ( 's' , $time_adj );
echo " <select name= \" mm \" > \n " ;
2005-09-18 21:44:14 +02:00
for ( $i = 1 ; $i < 13 ; $i = $i + 1 ) {
2004-04-30 10:56:49 +02:00
echo " \t \t \t <option value= \" $i\ " " ;
if ( $i == $mm )
2005-09-18 21:44:14 +02:00
echo " selected='selected' " ;
2004-04-30 10:56:49 +02:00
if ( $i < 10 ) {
$ii = " 0 " . $i ;
} else {
$ii = " $i " ;
}
echo " > " . $month [ " $ii " ] . " </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 >
2005-11-06 07:21:50 +01:00
< input type = " text " id = " jj " name = " jj " value = " <?php echo $jj ; ?> " size = " 2 " maxlength = " 2 " />
< input type = " text " id = " aa " name = " aa " value = " <?php echo $aa ?> " size = " 4 " maxlength = " 5 " /> @
< input type = " text " id = " hh " name = " hh " value = " <?php echo $hh ?> " size = " 2 " maxlength = " 2 " /> :
< input type = " text " id = " mn " name = " mn " value = " <?php echo $mn ?> " size = " 2 " maxlength = " 2 " />
< input type = " hidden " id = " ss " name = " ss " value = " <?php echo $ss ?> " size = " 2 " maxlength = " 2 " />
2005-11-14 10:56:41 +01:00
< ? php
if ( $edit ) {
_e ( 'Existing timestamp' );
echo " : { $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
}
2004-05-17 21:40:56 +02:00
function check_admin_referer () {
2005-09-18 21:44:14 +02:00
$adminurl = strtolower ( get_settings ( 'siteurl' )) . '/wp-admin' ;
$referer = strtolower ( $_SERVER [ 'HTTP_REFERER' ]);
if ( ! strstr ( $referer , $adminurl ))
2005-05-09 20:26:53 +02:00
die ( __ ( 'Sorry, you need to <a href="http://codex.wordpress.org/Enable_Sending_Referrers">enable sending referrers</a> for this feature to work.' ));
do_action ( 'check_admin_referer' );
2004-05-17 21:40:56 +02:00
}
2005-08-20 03:56:27 +02:00
// insert_with_markers: Owen Winkler, fixed by Eric Anderson
2004-07-28 01:37:45 +02:00
// Inserts an array of strings into a file (.htaccess), placing it between
// BEGIN and END markers. Replaces existing marked info. Retains surrounding
// data. Creates file if none exists.
// Returns true on write success, false on failure.
function insert_with_markers ( $filename , $marker , $insertion ) {
2004-09-27 04:32:51 +02:00
if ( ! file_exists ( $filename ) || is_writeable ( $filename )) {
if ( ! file_exists ( $filename )) {
$markerdata = '' ;
} else {
$markerdata = explode ( " \n " , implode ( '' , file ( $filename )));
}
$f = fopen ( $filename , 'w' );
$foundit = false ;
if ( $markerdata ) {
$state = true ;
2005-09-18 21:44:14 +02:00
foreach ( $markerdata as $markerline ) {
if ( strstr ( $markerline , " # BEGIN { $marker } " ))
$state = false ;
if ( $state )
fwrite ( $f , " { $markerline } \n " );
2005-09-16 05:25:22 +02:00
if ( strstr ( $markerline , " # END { $marker } " )) {
2005-08-20 03:56:27 +02:00
fwrite ( $f , " # BEGIN { $marker } \n " );
2005-09-18 21:44:14 +02:00
if ( is_array ( $insertion ))
foreach ( $insertion as $insertline )
fwrite ( $f , " { $insertline } \n " );
2005-08-20 03:56:27 +02:00
fwrite ( $f , " # END { $marker } \n " );
2004-09-27 04:32:51 +02:00
$state = true ;
$foundit = true ;
}
}
}
if ( ! $foundit ) {
fwrite ( $f , " # BEGIN { $marker } \n " );
2005-09-18 21:44:14 +02:00
foreach ( $insertion as $insertline )
fwrite ( $f , " { $insertline } \n " );
2005-08-20 03:56:27 +02:00
fwrite ( $f , " # END { $marker } \n " );
2004-09-27 04:32:51 +02:00
}
fclose ( $f );
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
2004-07-28 01:37:45 +02:00
// Returns an array of strings from a file (.htaccess) from between BEGIN
// and END markers.
function extract_from_markers ( $filename , $marker ) {
2005-09-18 21:44:14 +02:00
$result = array ();
2004-07-28 01:37:45 +02:00
2004-09-27 04:32:51 +02:00
if ( ! file_exists ( $filename )) {
return $result ;
}
2005-09-18 21:44:14 +02:00
if ( $markerdata = explode ( " \n " , implode ( '' , file ( $filename ))));
2004-09-27 04:32:51 +02:00
{
$state = false ;
2005-09-18 21:44:14 +02:00
foreach ( $markerdata as $markerline ) {
if ( strstr ( $markerline , " # END { $marker } " ))
$state = false ;
if ( $state )
$result [] = $markerline ;
if ( strstr ( $markerline , " # BEGIN { $marker } " ))
$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 ;
if ( function_exists ( 'apache_get_modules' ) ) {
if ( ! in_array ( 'mod_rewrite' , apache_get_modules ()) )
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
2005-09-18 21:44:14 +02:00
if ( ! $wp_rewrite -> using_mod_rewrite_permalinks ())
2004-12-27 23:30:52 +01:00
return ;
2005-09-18 21:44:14 +02:00
if ( ! (( ! file_exists ( $home_path . '.htaccess' ) && is_writable ( $home_path )) || is_writable ( $home_path . '.htaccess' )))
2004-12-27 23:30:52 +01:00
return ;
2005-11-11 00:25:39 +01:00
if ( ! got_mod_rewrite ())
2004-12-27 23:30:52 +01:00
return ;
$rules = explode ( " \n " , $wp_rewrite -> mod_rewrite_rules ());
insert_with_markers ( $home_path . '.htaccess' , 'WordPress' , $rules );
2004-10-06 04:18:37 +02:00
}
2005-09-18 21:44:14 +02:00
function the_quicktags () {
// Browser detection sucks, but until Safari supports the JS needed for this to work people just assume it's a bug in WP
if ( ! strstr ( $_SERVER [ 'HTTP_USER_AGENT' ], 'Safari' ))
: echo '
< div id = " quicktags " >
< script src = " ../wp-includes/js/quicktags.js " type = " text/javascript " ></ script >
< script type = " text/javascript " > edToolbar (); </ script >
' ;
2004-09-09 19:51:33 +02:00
echo '</div>' ;
2005-09-18 21:44:14 +02:00
endif ;
2004-09-09 19:51:33 +02:00
}
2004-09-16 20:09:32 +02:00
function validate_current_theme () {
$theme_loc = 'wp-content/themes' ;
2005-09-18 21:44:14 +02:00
$theme_root = ABSPATH . $theme_loc ;
2004-09-16 20:09:32 +02:00
$template = get_settings ( 'template' );
$stylesheet = get_settings ( 'stylesheet' );
2005-09-18 21:44:14 +02:00
if (( $template != 'default' ) && ( ! file_exists ( " $theme_root / $template /index.php " ))) {
2004-09-16 20:09:32 +02:00
update_option ( 'template' , 'default' );
update_option ( 'stylesheet' , 'default' );
2004-10-06 08:20:52 +02:00
do_action ( 'switch_theme' , 'Default' );
2004-09-16 20:09:32 +02:00
return false ;
}
2005-09-18 21:44:14 +02:00
if (( $stylesheet != 'default' ) && ( ! file_exists ( " $theme_root / $stylesheet /style.css " ))) {
2004-09-16 20:09:32 +02:00
update_option ( 'template' , 'default' );
update_option ( 'stylesheet' , 'default' );
2004-10-06 08:20:52 +02:00
do_action ( 'switch_theme' , 'Default' );
2004-09-16 20:09:32 +02:00
return false ;
}
return true ;
}
2004-10-25 01:48:51 +02:00
function get_broken_themes () {
global $wp_broken_themes ;
get_themes ();
return $wp_broken_themes ;
}
2004-10-06 07:11:11 +02:00
function get_page_templates () {
$themes = get_themes ();
$theme = get_current_theme ();
$templates = $themes [ $theme ][ 'Template Files' ];
2005-09-18 21:44:14 +02:00
$page_templates = array ();
2004-10-06 07:11:11 +02:00
2005-09-18 21:44:14 +02:00
if ( is_array ( $templates )) {
2005-03-23 02:14:05 +01:00
foreach ( $templates as $template ) {
2005-09-18 21:44:14 +02:00
$template_data = implode ( '' , file ( ABSPATH . $template ));
2005-03-23 02:14:05 +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
2005-09-18 21:44:14 +02:00
if ( ! empty ( $name )) {
2005-03-23 02:14:05 +01:00
$page_templates [ trim ( $name )] = basename ( $template );
}
2004-10-06 07:11:11 +02:00
}
}
return $page_templates ;
}
function page_template_dropdown ( $default = '' ) {
$templates = get_page_templates ();
2005-09-18 21:44:14 +02:00
foreach ( array_keys ( $templates ) as $template )
: if ( $default == $templates [ $template ])
$selected = " selected='selected' " ;
else
$selected = '' ;
echo " \n \t <option value=' " . $templates [ $template ] . " ' $selected > $template </option> " ;
endforeach ;
2004-10-06 07:11:11 +02:00
}
2004-10-06 04:18:37 +02:00
function parent_dropdown ( $default = 0 , $parent = 0 , $level = 0 ) {
2004-11-24 01:12:46 +01:00
global $wpdb , $post_ID ;
2004-10-05 10:27:13 +02:00
$items = $wpdb -> get_results ( " SELECT ID, post_parent, post_title FROM $wpdb->posts WHERE post_parent = $parent AND post_status = 'static' ORDER BY menu_order " );
2004-11-24 01:12:46 +01:00
2004-10-05 10:27:13 +02:00
if ( $items ) {
foreach ( $items as $item ) {
2004-11-24 01:12:46 +01:00
// A page cannot be it's own parent.
2005-09-18 21:44:14 +02:00
if ( ! empty ( $post_ID )) {
2004-11-24 01:12:46 +01:00
if ( $item -> ID == $post_ID ) {
continue ;
}
}
2004-10-05 10:27:13 +02:00
$pad = str_repeat ( ' ' , $level * 3 );
2004-10-06 04:18:37 +02:00
if ( $item -> ID == $default )
2004-10-05 10:27:13 +02:00
$current = ' selected="selected"' ;
else
$current = '' ;
2004-12-12 07:31:01 +01:00
echo " \n \t <option value=' $item->ID ' $current > $pad $item->post_title </option> " ;
2005-09-18 21:44:14 +02:00
parent_dropdown ( $default , $item -> ID , $level + 1 );
2004-10-05 10:27:13 +02:00
}
} else {
return false ;
}
}
2004-10-18 06:50:08 +02:00
function user_can_access_admin_page () {
global $pagenow ;
global $menu ;
global $submenu ;
2004-12-08 23:32:49 +01:00
$parent = get_admin_page_parent ();
2004-10-18 06:50:08 +02:00
foreach ( $menu as $menu_array ) {
//echo "parent array: " . $menu_array[2];
if ( $menu_array [ 2 ] == $parent ) {
2005-09-18 21:44:14 +02:00
if ( ! current_user_can ( $menu_array [ 1 ])) {
2004-10-18 06:50:08 +02:00
return false ;
} else {
break ;
}
}
}
2005-09-18 21:44:14 +02:00
if ( isset ( $submenu [ $parent ])) {
2004-10-18 06:50:08 +02:00
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( $submenu_array [ 2 ] == $pagenow ) {
2005-09-18 21:44:14 +02:00
if ( ! current_user_can ( $submenu_array [ 1 ])) {
2004-10-18 06:50:08 +02:00
return false ;
} else {
return true ;
}
}
}
}
2005-09-18 21:44:14 +02: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 ;
2005-09-18 21:44:14 +02:00
if ( isset ( $title ) && ! empty ( $title )) {
2004-10-19 05:03:06 +02:00
return $title ;
}
2005-01-30 08:34:03 +01:00
$parent = get_admin_page_parent ();
2005-09-18 21:44:14 +02:00
if ( empty ( $parent )) {
2005-01-30 08:34:03 +01:00
foreach ( $menu as $menu_array ) {
2005-09-18 21:44:14 +02:00
if ( isset ( $menu_array [ 3 ])) {
2005-01-30 08:34:03 +01:00
if ( $menu_array [ 2 ] == $pagenow ) {
$title = $menu_array [ 3 ];
return $menu_array [ 3 ];
2005-09-18 21:44:14 +02:00
} else
if ( isset ( $plugin_page ) && ( $plugin_page == $menu_array [ 2 ])) {
$title = $menu_array [ 3 ];
return $menu_array [ 3 ];
}
2005-01-30 08:34:03 +01:00
}
}
} else {
foreach ( array_keys ( $submenu ) as $parent ) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
2005-09-18 21:44:14 +02:00
if ( isset ( $submenu_array [ 3 ])) {
2005-01-30 08:34:03 +01:00
if ( $submenu_array [ 2 ] == $pagenow ) {
$title = $submenu_array [ 3 ];
return $submenu_array [ 3 ];
2005-09-18 21:44:14 +02:00
} else
if ( isset ( $plugin_page ) && ( $plugin_page == $submenu_array [ 2 ])) {
$title = $submenu_array [ 3 ];
return $submenu_array [ 3 ];
}
2004-10-19 05:03:06 +02:00
}
}
}
}
return '' ;
}
function get_admin_page_parent () {
global $parent_file ;
2005-02-25 17:11:27 +01:00
global $menu ;
2004-10-19 05:03:06 +02:00
global $submenu ;
global $pagenow ;
global $plugin_page ;
2005-09-18 21:44:14 +02:00
if ( isset ( $parent_file ) && ! empty ( $parent_file )) {
2004-10-19 05:03:06 +02:00
return $parent_file ;
}
2005-09-18 21:44:14 +02:00
if ( $pagenow == 'admin.php' && isset ( $plugin_page )) {
2005-02-25 17:11:27 +01:00
foreach ( $menu as $parent_menu ) {
if ( $parent_menu [ 2 ] == $plugin_page ) {
$parent_file = $plugin_page ;
return $plugin_page ;
}
}
}
2005-09-18 21:44:14 +02:00
2004-10-19 05:03:06 +02:00
foreach ( array_keys ( $submenu ) as $parent ) {
foreach ( $submenu [ $parent ] as $submenu_array ) {
if ( $submenu_array [ 2 ] == $pagenow ) {
$parent_file = $parent ;
return $parent ;
2005-09-18 21:44:14 +02:00
} else
if ( isset ( $plugin_page ) && ( $plugin_page == $submenu_array [ 2 ])) {
$parent_file = $parent ;
return $parent ;
}
2004-10-19 05:03:06 +02:00
}
}
$parent_file = '' ;
return '' ;
}
2005-02-25 17:11:27 +01:00
function add_menu_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
2005-02-07 02:15:06 +01:00
global $menu , $admin_page_hooks ;
2004-11-26 02:50:37 +01:00
2004-11-28 01:33:04 +01:00
$file = plugin_basename ( $file );
2004-11-26 02:50:37 +01:00
2005-09-18 21:44:14 +02:00
$menu [] = array ( $menu_title , $access_level , $file , $page_title );
2005-02-07 02:15:06 +01:00
$admin_page_hooks [ $file ] = sanitize_title ( $menu_title );
2005-02-25 17:11:27 +01:00
$hookname = get_plugin_page_hookname ( $file , '' );
2005-09-18 21:44:14 +02:00
if ( ! empty ( $function ) && ! empty ( $hookname ))
2005-02-25 17:11:27 +01:00
add_action ( $hookname , $function );
return $hookname ;
2004-11-26 02:50:37 +01:00
}
2005-02-07 02:15:06 +01:00
function add_submenu_page ( $parent , $page_title , $menu_title , $access_level , $file , $function = '' ) {
2004-10-19 05:03:06 +02:00
global $submenu ;
2004-12-04 06:02:07 +01:00
global $menu ;
2004-10-19 05:03:06 +02:00
2004-12-04 06:02:07 +01:00
$parent = plugin_basename ( $parent );
2004-11-28 01:33:04 +01:00
$file = plugin_basename ( $file );
2004-10-19 05:03:06 +02:00
2004-12-04 06:02:07 +01:00
// If the parent doesn't already have a submenu, add a link to the parent
// as the first item in the submenu. If the submenu file is the same as the
// parent file someone is trying to link back to the parent manually. In
// this case, don't automatically add a link back to avoid duplication.
2005-09-18 21:44:14 +02:00
if ( ! isset ( $submenu [ $parent ]) && $file != $parent ) {
2004-12-04 06:02:07 +01:00
foreach ( $menu as $parent_menu ) {
if ( $parent_menu [ 2 ] == $parent ) {
$submenu [ $parent ][] = $parent_menu ;
}
}
}
2005-09-18 21:44:14 +02:00
$submenu [ $parent ][] = array ( $menu_title , $access_level , $file , $page_title );
2005-02-07 02:15:06 +01:00
$hookname = get_plugin_page_hookname ( $file , $parent );
2005-09-18 21:44:14 +02:00
if ( ! empty ( $function ) && ! empty ( $hookname ))
2005-02-07 02:15:06 +01:00
add_action ( $hookname , $function );
return $hookname ;
2004-10-18 06:50:08 +02:00
}
2005-02-07 02:15:06 +01:00
function add_options_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
2005-11-17 00:32:38 +01:00
return add_submenu_page ( 'options-general.php' , $page_title , $menu_title , $access_level , $file , $function );
2004-11-26 02:50:37 +01:00
}
2005-02-07 02:15:06 +01:00
function add_management_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
return add_submenu_page ( 'edit.php' , $page_title , $menu_title , $access_level , $file , $function );
2004-11-26 02:50:37 +01:00
}
2004-11-17 04:15:44 +01:00
2005-08-30 01:40:32 +02:00
function add_theme_page ( $page_title , $menu_title , $access_level , $file , $function = '' ) {
2005-09-18 21:44:14 +02:00
return add_submenu_page ( 'themes.php' , $page_title , $menu_title , $access_level , $file , $function );
2005-08-30 01:40:32 +02:00
}
2004-12-30 19:05:46 +01:00
function validate_file ( $file , $allowed_files = '' ) {
2005-09-18 21:44:14 +02:00
if ( false !== strpos ( $file , './' ))
2004-12-30 19:05:46 +01:00
return 1 ;
2005-09-18 21:44:14 +02:00
if ( ':' == substr ( $file , 1 , 1 ))
2004-12-30 19:05:46 +01:00
return 2 ;
2005-09-18 21:44:14 +02:00
if ( ! empty ( $allowed_files ) && ( ! in_array ( $file , $allowed_files )))
2004-12-30 19:05:46 +01:00
return 3 ;
return 0 ;
}
2004-11-17 04:15:44 +01:00
function validate_file_to_edit ( $file , $allowed_files = '' ) {
2004-12-30 19:05:46 +01:00
$file = stripslashes ( $file );
$code = validate_file ( $file , $allowed_files );
2005-09-18 21:44:14 +02:00
if ( ! $code )
2004-12-30 19:05:46 +01:00
return $file ;
switch ( $code ) {
2005-09-18 21:44:14 +02:00
case 1 :
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.' ));
case 2 :
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 :
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 () {
2004-11-17 04:15:44 +01:00
$home = get_settings ( 'home' );
2005-09-18 21:44:14 +02:00
if ( $home != '' && $home != get_settings ( 'siteurl' )) {
2004-12-23 01:53:56 +01:00
$home_path = parse_url ( $home );
2005-02-01 07:59:44 +01:00
$home_path = $home_path [ 'path' ];
2004-12-23 01:53:56 +01:00
$root = str_replace ( $_SERVER [ " PHP_SELF " ], '' , $_SERVER [ " SCRIPT_FILENAME " ]);
2005-09-18 21:44:14 +02:00
$home_path = trailingslashit ( $root . $home_path );
2004-12-23 01:53:56 +01:00
} else {
$home_path = ABSPATH ;
}
return $home_path ;
}
function get_real_file_to_edit ( $file ) {
2005-09-18 21:44:14 +02:00
if ( 'index.php' == $file || '.htaccess' == $file ) {
$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 ;
}
2005-09-18 21:44:14 +02: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
2005-09-18 21:44:14 +02: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
function get_file_description ( $file ) {
global $wp_file_descriptions ;
2005-09-18 21:44:14 +02:00
if ( isset ( $wp_file_descriptions [ basename ( $file )])) {
2005-02-14 05:24:25 +01:00
return $wp_file_descriptions [ basename ( $file )];
2005-09-18 21:44:14 +02:00
}
elseif ( file_exists ( ABSPATH . $file )) {
$template_data = implode ( '' , file ( ABSPATH . $file ));
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
}
2005-09-18 21:44:14 +02:00
return basename ( $file );
2004-11-17 04:15:44 +01:00
}
function update_recently_edited ( $file ) {
$oldfiles = ( array ) get_option ( 'recently_edited' );
if ( $oldfiles ) {
$oldfiles = array_reverse ( $oldfiles );
$oldfiles [] = $file ;
$oldfiles = array_reverse ( $oldfiles );
$oldfiles = array_unique ( $oldfiles );
2005-09-18 21:44:14 +02:00
if ( 5 < count ( $oldfiles ))
2004-11-17 04:15:44 +01:00
array_pop ( $oldfiles );
} else {
$oldfiles [] = $file ;
}
update_option ( 'recently_edited' , $oldfiles );
}
2004-11-26 03:29:45 +01:00
function get_plugin_data ( $plugin_file ) {
$plugin_data = implode ( '' , file ( $plugin_file ));
preg_match ( " |Plugin Name:(.*)|i " , $plugin_data , $plugin_name );
preg_match ( " |Plugin URI:(.*)|i " , $plugin_data , $plugin_uri );
preg_match ( " |Description:(.*)|i " , $plugin_data , $description );
preg_match ( " |Author:(.*)|i " , $plugin_data , $author_name );
preg_match ( " |Author URI:(.*)|i " , $plugin_data , $author_uri );
2005-09-18 21:44:14 +02:00
if ( preg_match ( " |Version:(.*)|i " , $plugin_data , $version ))
2004-11-26 03:29:45 +01:00
$version = $version [ 1 ];
else
2005-09-18 21:44:14 +02:00
$version = '' ;
2004-11-26 03:29:45 +01:00
$description = wptexturize ( $description [ 1 ]);
$name = $plugin_name [ 1 ];
$name = trim ( $name );
$plugin = $name ;
if ( '' != $plugin_uri [ 1 ] && '' != $name ) {
2005-09-18 21:44:14 +02:00
$plugin = '<a href="' . $plugin_uri [ 1 ] . '" title="' . __ ( 'Visit plugin homepage' ) . '">' . $plugin . '</a>' ;
2004-11-26 03:29:45 +01:00
}
if ( '' == $author_uri [ 1 ]) {
$author = $author_name [ 1 ];
} else {
2005-09-18 21:44:14 +02:00
$author = '<a href="' . $author_uri [ 1 ] . '" title="' . __ ( 'Visit author homepage' ) . '">' . $author_name [ 1 ] . '</a>' ;
2004-11-26 03:29:45 +01:00
}
2005-09-18 21:44:14 +02: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 ;
2005-09-18 21:44:14 +02: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 ();
2004-11-26 03:29:45 +01:00
$plugin_loc = 'wp-content/plugins' ;
2005-09-18 21:44:14 +02:00
$plugin_root = ABSPATH . $plugin_loc ;
2004-11-26 03:29:45 +01:00
// Files in wp-content/plugins directory
$plugins_dir = @ dir ( $plugin_root );
if ( $plugins_dir ) {
2005-09-18 21:44:14 +02:00
while (( $file = $plugins_dir -> read ()) !== false ) {
if ( preg_match ( '|^\.+$|' , $file ))
2004-11-28 01:33:04 +01:00
continue ;
2005-09-18 21:44:14 +02:00
if ( is_dir ( $plugin_root . '/' . $file )) {
$plugins_subdir = @ dir ( $plugin_root . '/' . $file );
2004-11-28 01:33:04 +01:00
if ( $plugins_subdir ) {
2005-09-18 21:44:14 +02:00
while (( $subfile = $plugins_subdir -> read ()) !== false ) {
if ( preg_match ( '|^\.+$|' , $subfile ))
2004-11-28 01:33:04 +01:00
continue ;
2005-09-18 21:44:14 +02:00
if ( preg_match ( '|\.php$|' , $subfile ))
2004-11-28 01:33:04 +01:00
$plugin_files [] = " $file / $subfile " ;
}
}
} else {
2005-09-18 21:44:14 +02: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
}
}
if ( ! $plugins_dir || ! $plugin_files ) {
return $wp_plugins ;
}
sort ( $plugin_files );
2005-09-18 21:44:14 +02:00
foreach ( $plugin_files as $plugin_file ) {
2005-11-16 04:27:22 +01:00
if ( ! is_readable ( " $plugin_root / $plugin_file " ))
continue ;
2004-11-26 03:29:45 +01:00
$plugin_data = get_plugin_data ( " $plugin_root / $plugin_file " );
2005-09-18 21:44:14 +02:00
if ( empty ( $plugin_data [ 'Name' ])) {
2004-11-26 03:29:45 +01:00
continue ;
}
2004-11-28 01:33:04 +01:00
$wp_plugins [ plugin_basename ( $plugin_file )] = $plugin_data ;
2004-11-26 03:29:45 +01:00
}
return $wp_plugins ;
}
2005-02-07 02:15:06 +01:00
function get_plugin_page_hookname ( $plugin_page , $parent_page ) {
global $admin_page_hooks ;
2005-02-25 17:11:27 +01:00
$parent = get_admin_page_parent ();
2005-09-18 21:44:14 +02: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
if ( isset ( $admin_page_hooks [ $parent ]))
$page_type = $admin_page_hooks [ $parent ];
} else
if ( isset ( $admin_page_hooks [ $parent_page ])) {
$page_type = $admin_page_hooks [ $parent_page ];
} else {
$page_type = 'admin' ;
}
2005-02-07 02:15:06 +01:00
$plugin_name = preg_replace ( '!\.php!' , '' , $plugin_page );
2005-09-18 21:44:14 +02:00
return $page_type . '_page_' . $plugin_name ;
2005-02-07 02:15:06 +01:00
}
function get_plugin_page_hook ( $plugin_page , $parent_page ) {
global $wp_filter ;
2005-09-18 21:44:14 +02:00
2005-02-07 02:15:06 +01:00
$hook = get_plugin_page_hookname ( $plugin_page , $parent_page );
2005-09-18 21:44:14 +02:00
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 () {
$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
}
2005-09-18 21:44:14 +02:00
if ( strstr ( $_SERVER [ 'HTTP_USER_AGENT' ], 'MSIE' ))
2005-08-27 21:18:26 +02:00
add_action ( 'admin_footer' , 'browse_happy' );
2005-04-19 04:16:57 +02:00
2005-09-18 21:44:14 +02:00
function documentation_link ( $for ) {
2005-07-09 00:59:15 +02:00
return ;
}
2005-08-21 09:03:23 +02:00
function register_importer ( $id , $name , $description , $callback ) {
global $wp_importers ;
2005-09-18 21:44:14 +02: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 ();
$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
// Returns an array containing the current upload directory's path and url, or an error message.
function wp_upload_dir () {
if ( defined ( 'UPLOADS' ) )
$dir = UPLOADS ;
else
$dir = 'wp-content/uploads' ;
$path = ABSPATH . $dir ;
2005-10-28 03:12:54 +02:00
// Give the new dirs the same perms as wp-content.
$stat = stat ( ABSPATH . 'wp-content' );
$dir_perms = $stat [ 'mode' ] & 0000777 ; // Get the permission bits.
2005-09-27 01:55:36 +02:00
// Make sure we have an uploads dir
if ( ! file_exists ( $path ) ) {
if ( ! mkdir ( $path ) )
return array ( 'error' => " Unable to create directory $path . Is its parent directory writable by the server? " );
2005-10-28 03:12:54 +02:00
@ chmod ( $path , $dir_perms );
2005-09-27 01:55:36 +02:00
}
// Generate the yearly and monthly dirs
$time = current_time ( 'mysql' );
$y = substr ( $time , 0 , 4 );
$m = substr ( $time , 5 , 2 );
$pathy = " $path / $y " ;
$pathym = " $path / $y / $m " ;
// Make sure we have a yearly dir
if ( ! file_exists ( $pathy ) ) {
if ( ! mkdir ( $pathy ) )
return array ( 'error' => " Unable to create directory $pathy . Is $path writable? " );
2005-10-28 03:12:54 +02:00
@ chmod ( $pathy , $dir_perms );
2005-09-27 01:55:36 +02:00
}
// Make sure we have a monthly dir
if ( ! file_exists ( $pathym ) ) {
if ( ! mkdir ( $pathym ) )
return array ( 'error' => " Unable to create directory $pathym . Is $pathy writable? " );
2005-10-28 03:12:54 +02:00
@ chmod ( $pathym , $dir_perms );
2005-09-27 01:55:36 +02:00
}
2005-10-01 00:42:26 +02:00
$uploads = array ( 'path' => $pathym , 'url' => get_option ( 'siteurl' ) . " / $dir / $y / $m " , 'error' => false );
2005-09-27 01:55:36 +02:00
return apply_filters ( 'upload_dir' , $uploads );
}
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.
// overrides: an associative array of names=>values to override default variables with extract($overrides, EXTR_OVERWRITE).
// On success, returns an associative array of file attributes.
// On failure, returns $overrides['upload_error_handler'](&$file, $message) or array('error'=>$message).
function wp_handle_upload ( & $file , $overrides = false ) {
// The default error handler.
function wp_handle_upload_error ( & $file , $message ) {
return array ( 'error' => $message );
}
// 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'].
$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. " ));
// Accepted MIME types are set here as PCRE. Override with $override['mimes'].
$mimes = apply_filters ( 'upload_mimes' , array (
'image/jpeg' => 'jpg|jpeg|jpe' ,
'image/gif' => 'gif' ,
'image/(png|x-png)' => 'png' ,
'image/(bmp|x-bmp|x-ms-bmp)' => 'bmp' ,
'image/(tiff|x-tiff)' => 'tif|tiff' ,
'image/(ico|x-ico)' => 'ico' ,
'video/(asf|x-asf|x-ms-asf)' => 'asf|asx|wma|wax|wmv|wmx' ,
'video/(wmv|x-wmv|x-ms-wmv)' => 'wmv' ,
'video/(msvideo|x-msvideo)' => 'avi' ,
'video/(quicktime|x-quicktime)' => 'mov|qt' ,
'video/(mpeg|x-mpeg)' => 'mpeg|mpg|mpe' ,
'text/plain' => 'txt|c|cc|h|php' ,
'text/richtext' => 'rtx' ,
'text/css' => 'css' ,
'text/html' => 'htm|html' ,
'text/javascript' => 'js' ,
'audio/(mpeg|x-mpeg|mpeg3|x-mpeg3)' => 'mp3' ,
'audio/x-realaudio' => 'ra|ram' ,
'audio/(wav|x-wav)' => 'wav' ,
'audio/(ogg|x-ogg)' => 'ogg' ,
'audio/(midi|x-midi)' => 'mid|midi' ,
'application/pdf' => 'pdf' ,
'application/msword' => 'doc' ,
'application/mspowerpoint' => 'pot|pps|ppt' ,
'application/mswrite' => 'wri' ,
'application/(msexcel|vnd.ms-excel)' => 'xla|xls|xlt|xlw' ,
'application/msaccess' => 'mdb' ,
'application/msproject' => 'mpp' ,
'application/x-shockwave-flash' => 'swf' ,
'application/java' => 'class' ,
'application/x-tar' => 'tar' ,
'application/(zip|x-zip-compressed)' => 'zip' ,
'application/(x-gzip|x-gzip-compressed)' => 'gz|gzip' ));
// For security, we never trust HTTP Content-Type headers unless the user overrides this.
$trust_content_type = false ;
// All tests are on by default. Most can be turned off by $override[{test_name}] = false;
$test_form = true ;
$test_size = true ;
$test_type = true ;
// Install user overrides. Did we mention that this voids your warranty?
if ( is_array ( $overrides ) )
extract ( $overrides , EXTR_OVERWRITE );
// A correct form post will pass this test.
if ( $test_form && ( ! isset ( $_POST [ 'action' ]) || ( $_POST [ 'action' ] != $action )) )
return $upload_error_handler ( $file , __ ( 'Invalid form submission.' ));
// A successful upload will pass this test. It makes no sense to override this one.
if ( $file [ 'error' ] > 0 )
return $upload_error_handler ( $file , $upload_error_strings [ $file [ 'error' ]]);
// A non-empty file will pass this test.
if ( $test_size && ! ( $file [ 'size' ] > 0 ) )
return $upload_error_handler ( $file , __ ( 'File is empty. Please upload something more substantial.' ));
// A properly uploaded file will pass this test. There should be no reason to override this one.
if ( ! is_uploaded_file ( $file [ 'tmp_name' ]) )
return $upload_error_handler ( $file , __ ( 'Specified file failed upload test.' ));
// A correct MIME type will pass this test. We can't always determine it programatically, so we'll trust the HTTP headers.
if ( $test_type ) {
$type = false ;
$ext = false ;
foreach ( $mimes as $mime_preg => $ext_preg ) {
$mime_preg = '!^' . $mime_preg . '$!i' ;
$ext_preg = '![^.]\.(' . $ext_preg . ')$!i' ;
if ( preg_match ( $mime_preg , $file [ 'type' ], $type ) ) {
if ( preg_match ( $ext_preg , $file [ 'name' ], $ext ) ) {
break ;
} else {
return $upload_error_handler ( $file , __ ( 'File extension does not match file type. Try another.' ));
}
}
}
if ( ! $type && $ext )
return $upload_error_handler ( $file , __ ( 'File type does not meet security guidelines. Try another.' ));
$type = $type [ 0 ];
$ext = $ext [ 1 ];
}
// A writable uploads dir will pass this test. Again, there's no point overriding this one.
if ( ! ( ( $uploads = wp_upload_dir () ) && false === $uploads [ 'error' ] ) )
return $upload_error_handler ( $file , $uploads [ 'error' ]);
// Increment the file number until we have a unique file to save in $dir. Use $override['unique_filename_callback'] if supplied.
if ( isset ( $unique_filename_callback ) && function_exists ( $unique_filename_callback ) ) {
$filename = $unique_filename_callback ( $uploads [ 'path' ], $file [ 'name' ]);
} else {
$number = '' ;
$filename = $file [ 'name' ];
while ( file_exists ( $uploads [ 'path' ] . " / $filename " ) )
$filename = str_replace ( " $number . $ext " , ++ $number . " . $ext " , $filename );
}
// Move the file to the uploads dir
$new_file = $uploads [ 'path' ] . " / $filename " ;
if ( false === move_uploaded_file ( $file [ 'tmp_name' ], $new_file ) )
die ( 'The uploaded file could not be moved to $file.' );
// Set correct file permissions
$stat = stat ( dirname ( $new_file ));
$perms = $stat [ 'mode' ] & 0000777 ;
@ chmod ( $new_file , $perms );
// Compute the URL
$url = $uploads [ 'url' ] . " / $filename " ;
return array ( 'file' => $new_file , 'url' => $url );
}
2005-11-11 02:27:58 +01:00
function wp_shrink_dimensions ( $width , $height , $wmax = 128 , $hmax = 96 ) {
if ( $height <= $hmax && $width <= $wmax )
return array ( $width , $height );
elseif ( $width / $height > $wmax / $hmax )
return array ( $wmax , ( int ) ( $height / $width * $wmax ));
else
return array (( int ) ( $width / $height * $hmax ), $hmax );
}
2005-11-16 03:07:56 +01:00
function wp_import_cleanup ( $id ) {
wp_delete_attachment ( $id );
2005-11-16 00:39:32 +01:00
}
function wp_import_upload_form ( $action ) {
?>
< script type = " text/javascript " >
function cancelUpload () {
o = document . getElementById ( 'uploadForm' );
o . method = 'GET' ;
o . action . value = 'view' ;
o . submit ();
}
</ script >
< form enctype = " multipart/form-data " id = " uploadForm " method = " POST " action = " <?php echo $action ?> " >
< label for = " upload " >< ? php _e ( 'File:' ); ?> </label><input type="file" id="upload" name="import" />
< input type = " hidden " name = " action " value = " save " />
< div id = " buttons " >
< input type = " submit " value = " <?php _e('Import'); ?> " />
< input type = " button " value = " <?php _e('Cancel'); ?> " onclick = " cancelUpload() " />
</ div >
</ form >
< ? php
}
function wp_import_handle_upload () {
$overrides = array ( 'test_form' => false , 'test_type' => false );
$file = wp_handle_upload ( $_FILES [ 'import' ], $overrides );
if ( isset ( $file [ 'error' ]) )
return $file ;
$url = $file [ 'url' ];
$file = $file [ 'file' ];
$filename = basename ( $file );
// Construct the object array
$object = array (
'post_title' => $filename ,
'post_content' => $url ,
'post_mime_type' => 'import' ,
'guid' => $url
);
// Save the data
$id = wp_insert_attachment ( $object , $file );
return array ( 'file' => $file , 'id' => $id );
}
2005-11-18 10:25:47 +01:00
?>