wp/wp-admin/includes/ajax-actions.php
author ymh <ymh.work@gmail.com>
Wed, 06 Nov 2013 03:21:17 +0000
changeset 0 d970ebf37754
child 5 5e2f62d02dcd
permissions -rw-r--r--
first import
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * WordPress Core Ajax Handlers.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * @package WordPress
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 * @subpackage Administration
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
/*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
 * No-privilege Ajax handlers.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
 * Heartbeat API (experimental)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
 * Runs when the user is not logged in.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
function wp_ajax_nopriv_heartbeat() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
	$response = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
	// screen_id is the same as $current_screen->id and the JS global 'pagenow'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
	if ( ! empty($_POST['screen_id']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
		$screen_id = sanitize_key($_POST['screen_id']);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
		$screen_id = 'front';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
	if ( ! empty($_POST['data']) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
		$data = wp_unslash( (array) $_POST['data'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
		/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
		 * Filter Heartbeat AJAX response in no-privilege environments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
		 * @since 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
		 * @param array|object $response  The no-priv Heartbeat response object or array.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
		 * @param array        $data      An array of data passed via $_POST.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
		 * @param string       $screen_id The screen id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
		 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
		$response = apply_filters( 'heartbeat_nopriv_received', $response, $data, $screen_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
	 * Filter Heartbeat AJAX response when no data is passed.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
	 * @since 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
	 * @param array|object $response  The Heartbeat response object or array.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
	 * @param string       $screen_id The screen id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
	$response = apply_filters( 'heartbeat_nopriv_send', $response, $screen_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
	 * Fires when Heartbeat ticks in no-privilege environments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
	 * Allows the transport to be easily replaced with long-polling.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
	 * @since 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
	 * @param array|object $response  The no-priv Heartbeat response.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
	 * @param string       $screen_id The screen id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
	do_action( 'heartbeat_nopriv_tick', $response, $screen_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
	// send the current time according to the server
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
	$response['server_time'] = time();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
	wp_send_json($response);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
/*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
 * GET-based Ajax handlers.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
function wp_ajax_fetch_list() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
	global $wp_list_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
	$list_class = $_GET['list_args']['class'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
	check_ajax_referer( "fetch-list-$list_class", '_ajax_fetch_list_nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
	$wp_list_table = _get_list_table( $list_class, array( 'screen' => $_GET['list_args']['screen']['id'] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
	if ( ! $wp_list_table )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
	if ( ! $wp_list_table->ajax_user_can() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
	$wp_list_table->ajax_response();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
	wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
function wp_ajax_ajax_tag_search() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
	if ( isset( $_GET['tax'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
		$taxonomy = sanitize_key( $_GET['tax'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
		$tax = get_taxonomy( $taxonomy );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
		if ( ! $tax )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
			wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
		if ( ! current_user_can( $tax->cap->assign_terms ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
			wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
	$s = wp_unslash( $_GET['q'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
	$comma = _x( ',', 'tag delimiter' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
	if ( ',' !== $comma )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
		$s = str_replace( $comma, ',', $s );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
	if ( false !== strpos( $s, ',' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
		$s = explode( ',', $s );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
		$s = $s[count( $s ) - 1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
	$s = trim( $s );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
	if ( strlen( $s ) < 2 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
		wp_die(); // require 2 chars for matching
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
	$results = get_terms( $taxonomy, array( 'name__like' => $s, 'fields' => 'names', 'hide_empty' => false ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
	echo join( $results, "\n" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
function wp_ajax_wp_compression_test() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
	if ( !current_user_can( 'manage_options' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
	if ( ini_get('zlib.output_compression') || 'ob_gzhandler' == ini_get('output_handler') ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
		update_site_option('can_compress_scripts', 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
	if ( isset($_GET['test']) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
		header( 'Expires: Wed, 11 Jan 1984 05:00:00 GMT' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
		header( 'Last-Modified: ' . gmdate( 'D, d M Y H:i:s' ) . ' GMT' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
		header( 'Cache-Control: no-cache, must-revalidate, max-age=0' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
		header( 'Pragma: no-cache' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
		header('Content-Type: application/x-javascript; charset=UTF-8');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
		$force_gzip = ( defined('ENFORCE_GZIP') && ENFORCE_GZIP );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
		$test_str = '"wpCompressionTest Lorem ipsum dolor sit amet consectetuer mollis sapien urna ut a. Eu nonummy condimentum fringilla tempor pretium platea vel nibh netus Maecenas. Hac molestie amet justo quis pellentesque est ultrices interdum nibh Morbi. Cras mattis pretium Phasellus ante ipsum ipsum ut sociis Suspendisse Lorem. Ante et non molestie. Porta urna Vestibulum egestas id congue nibh eu risus gravida sit. Ac augue auctor Ut et non a elit massa id sodales. Elit eu Nulla at nibh adipiscing mattis lacus mauris at tempus. Netus nibh quis suscipit nec feugiat eget sed lorem et urna. Pellentesque lacus at ut massa consectetuer ligula ut auctor semper Pellentesque. Ut metus massa nibh quam Curabitur molestie nec mauris congue. Volutpat molestie elit justo facilisis neque ac risus Ut nascetur tristique. Vitae sit lorem tellus et quis Phasellus lacus tincidunt nunc Fusce. Pharetra wisi Suspendisse mus sagittis libero lacinia Integer consequat ac Phasellus. Et urna ac cursus tortor aliquam Aliquam amet tellus volutpat Vestibulum. Justo interdum condimentum In augue congue tellus sollicitudin Quisque quis nibh."';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
		 if ( 1 == $_GET['test'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
		 	echo $test_str;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
		 	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
		 } elseif ( 2 == $_GET['test'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
			if ( !isset($_SERVER['HTTP_ACCEPT_ENCODING']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
				wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
			if ( false !== stripos( $_SERVER['HTTP_ACCEPT_ENCODING'], 'deflate') && function_exists('gzdeflate') && ! $force_gzip ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
				header('Content-Encoding: deflate');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
				$out = gzdeflate( $test_str, 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
			} elseif ( false !== stripos( $_SERVER['HTTP_ACCEPT_ENCODING'], 'gzip') && function_exists('gzencode') ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
				header('Content-Encoding: gzip');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
				$out = gzencode( $test_str, 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
			} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
				wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
			echo $out;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
			wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
		} elseif ( 'no' == $_GET['test'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
			update_site_option('can_compress_scripts', 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
		} elseif ( 'yes' == $_GET['test'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
			update_site_option('can_compress_scripts', 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
	wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
function wp_ajax_imgedit_preview() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
	$post_id = intval($_GET['postid']);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
	if ( empty($post_id) || !current_user_can('edit_post', $post_id) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
	check_ajax_referer( "image_editor-$post_id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
	include_once( ABSPATH . 'wp-admin/includes/image-edit.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
	if ( ! stream_preview_image($post_id) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
function wp_ajax_oembed_cache() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
	global $wp_embed;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
	$return = ( $wp_embed->cache_oembed( $_GET['post'] ) ) ? '1' : '0';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
	wp_die( $return );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
function wp_ajax_autocomplete_user() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
	if ( ! is_multisite() || ! current_user_can( 'promote_users' ) || wp_is_large_network( 'users' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
	/** This filter is documented in wp-admin/user-new.php */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
	if ( ! is_super_admin() && ! apply_filters( 'autocomplete_users_for_site_admins', false ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
	$return = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
	// Check the type of request
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
	if ( isset( $_REQUEST['autocomplete_type'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
		$type = $_REQUEST['autocomplete_type'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
		$type = 'add';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
	// Exclude current users of this blog
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
	if ( isset( $_REQUEST['site_id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
		$id = absint( $_REQUEST['site_id'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
		$id = get_current_blog_id();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
	$include_blog_users = ( $type == 'search' ? get_users( array( 'blog_id' => $id, 'fields' => 'ID' ) ) : array() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
	$exclude_blog_users = ( $type == 'add' ? get_users( array( 'blog_id' => $id, 'fields' => 'ID' ) ) : array() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
	$users = get_users( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
		'blog_id' => false,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
		'search'  => '*' . $_REQUEST['term'] . '*',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
		'include' => $include_blog_users,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
		'exclude' => $exclude_blog_users,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
		'search_columns' => array( 'user_login', 'user_nicename', 'user_email' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
	) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
	foreach ( $users as $user ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
		$return[] = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
			/* translators: 1: user_login, 2: user_email */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
			'label' => sprintf( __( '%1$s (%2$s)' ), $user->user_login, $user->user_email ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
			'value' => $user->user_login,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
		);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
	wp_die( json_encode( $return ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
function wp_ajax_dashboard_widgets() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
	require_once ABSPATH . 'wp-admin/includes/dashboard.php';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
	switch ( $_GET['widget'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
		case 'dashboard_incoming_links' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
			wp_dashboard_incoming_links();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
		case 'dashboard_primary' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
			wp_dashboard_primary();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
		case 'dashboard_secondary' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
			wp_dashboard_secondary();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
		case 'dashboard_plugins' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
			wp_dashboard_plugins();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
function wp_ajax_logged_in() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
/*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
 * Ajax helper.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
 * Sends back current comment total and new page links if they need to be updated.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
 * Contrary to normal success AJAX response ("1"), die with time() on success.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
 * @since 2.7
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
 * @param int $comment_id
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
 * @return die
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
function _wp_ajax_delete_comment_response( $comment_id, $delta = -1 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
	$total    = isset( $_POST['_total'] )    ? (int) $_POST['_total']    : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
	$per_page = isset( $_POST['_per_page'] ) ? (int) $_POST['_per_page'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
	$page     = isset( $_POST['_page'] )     ? (int) $_POST['_page']     : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
	$url      = isset( $_POST['_url'] )      ? esc_url_raw( $_POST['_url'] ) : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
	// JS didn't send us everything we need to know. Just die with success message
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
	if ( !$total || !$per_page || !$page || !$url )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
		wp_die( time() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
	$total += $delta;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
	if ( $total < 0 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
		$total = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
	// Only do the expensive stuff on a page-break, and about 1 other time per page
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
	if ( 0 == $total % $per_page || 1 == mt_rand( 1, $per_page ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
		$post_id = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
		$status = 'total_comments'; // What type of comment count are we looking for?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
		$parsed = parse_url( $url );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
		if ( isset( $parsed['query'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
			parse_str( $parsed['query'], $query_vars );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
			if ( !empty( $query_vars['comment_status'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
				$status = $query_vars['comment_status'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
			if ( !empty( $query_vars['p'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
				$post_id = (int) $query_vars['p'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
		$comment_count = wp_count_comments($post_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
		if ( isset( $comment_count->$status ) ) // We're looking for a known type of comment count
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
			$total = $comment_count->$status;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
			// else use the decremented value from above
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
	$time = time(); // The time since the last comment count
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
	$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
		'what' => 'comment',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
		'id' => $comment_id, // here for completeness - not used
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
		'supplemental' => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
			'total_items_i18n' => sprintf( _n( '1 item', '%s items', $total ), number_format_i18n( $total ) ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
			'total_pages' => ceil( $total / $per_page ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
			'total_pages_i18n' => number_format_i18n( ceil( $total / $per_page ) ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
			'total' => $total,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
			'time' => $time
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
		)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
	) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
/*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
 * POST-based Ajax handlers.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
function _wp_ajax_add_hierarchical_term() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
	$action = $_POST['action'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
	$taxonomy = get_taxonomy(substr($action, 4));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
	check_ajax_referer( $action, '_ajax_nonce-add-' . $taxonomy->name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
	if ( !current_user_can( $taxonomy->cap->edit_terms ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
	$names = explode(',', $_POST['new'.$taxonomy->name]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
	$parent = isset($_POST['new'.$taxonomy->name.'_parent']) ? (int) $_POST['new'.$taxonomy->name.'_parent'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
	if ( 0 > $parent )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
		$parent = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
	if ( $taxonomy->name == 'category' )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
		$post_category = isset($_POST['post_category']) ? (array) $_POST['post_category'] : array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
		$post_category = ( isset($_POST['tax_input']) && isset($_POST['tax_input'][$taxonomy->name]) ) ? (array) $_POST['tax_input'][$taxonomy->name] : array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
	$checked_categories = array_map( 'absint', (array) $post_category );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
	$popular_ids = wp_popular_terms_checklist($taxonomy->name, 0, 10, false);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
	foreach ( $names as $cat_name ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
		$cat_name = trim($cat_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
		$category_nicename = sanitize_title($cat_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
		if ( '' === $category_nicename )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
		if ( !$cat_id = term_exists( $cat_name, $taxonomy->name, $parent ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
			$cat_id = wp_insert_term( $cat_name, $taxonomy->name, array( 'parent' => $parent ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
		if ( is_wp_error( $cat_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
		else if ( is_array( $cat_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
			$cat_id = $cat_id['term_id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
		$checked_categories[] = $cat_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
		if ( $parent ) // Do these all at once in a second
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
		ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
			wp_terms_checklist( 0, array( 'taxonomy' => $taxonomy->name, 'descendants_and_self' => $cat_id, 'selected_cats' => $checked_categories, 'popular_cats' => $popular_ids ));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
		$data = ob_get_contents();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
		ob_end_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
		$add = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
			'what' => $taxonomy->name,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
			'id' => $cat_id,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
			'data' => str_replace( array("\n", "\t"), '', $data),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
			'position' => -1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
		);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
	if ( $parent ) { // Foncy - replace the parent and all its children
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
		$parent = get_term( $parent, $taxonomy->name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
		$term_id = $parent->term_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
		while ( $parent->parent ) { // get the top parent
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
			$parent = get_term( $parent->parent, $taxonomy->name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
			if ( is_wp_error( $parent ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
			$term_id = $parent->term_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
		ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
			wp_terms_checklist( 0, array('taxonomy' => $taxonomy->name, 'descendants_and_self' => $term_id, 'selected_cats' => $checked_categories, 'popular_cats' => $popular_ids));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
		$data = ob_get_contents();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
		ob_end_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
		$add = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
			'what' => $taxonomy->name,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
			'id' => $term_id,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
			'data' => str_replace( array("\n", "\t"), '', $data),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
			'position' => -1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
		);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
	ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
		wp_dropdown_categories( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
			'taxonomy' => $taxonomy->name, 'hide_empty' => 0, 'name' => 'new'.$taxonomy->name.'_parent', 'orderby' => 'name',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
			'hierarchical' => 1, 'show_option_none' => '&mdash; '.$taxonomy->labels->parent_item.' &mdash;'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
	$sup = ob_get_contents();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
	ob_end_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
	$add['supplemental'] = array( 'newcat_parent' => $sup );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
	$x = new WP_Ajax_Response( $add );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
function wp_ajax_delete_comment() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
	$id = isset( $_POST['id'] ) ? (int) $_POST['id'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
	if ( !$comment = get_comment( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
		wp_die( time() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
	if ( ! current_user_can( 'edit_comment', $comment->comment_ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
	check_ajax_referer( "delete-comment_$id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
	$status = wp_get_comment_status( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
	$delta = -1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
	if ( isset($_POST['trash']) && 1 == $_POST['trash'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
		if ( 'trash' == $status )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
			wp_die( time() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
		$r = wp_trash_comment( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
	} elseif ( isset($_POST['untrash']) && 1 == $_POST['untrash'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
		if ( 'trash' != $status )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
			wp_die( time() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
		$r = wp_untrash_comment( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
		if ( ! isset( $_POST['comment_status'] ) || $_POST['comment_status'] != 'trash' ) // undo trash, not in trash
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
			$delta = 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
	} elseif ( isset($_POST['spam']) && 1 == $_POST['spam'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
		if ( 'spam' == $status )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
			wp_die( time() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
		$r = wp_spam_comment( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
	} elseif ( isset($_POST['unspam']) && 1 == $_POST['unspam'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
		if ( 'spam' != $status )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
			wp_die( time() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
		$r = wp_unspam_comment( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
		if ( ! isset( $_POST['comment_status'] ) || $_POST['comment_status'] != 'spam' ) // undo spam, not in spam
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
			$delta = 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
	} elseif ( isset($_POST['delete']) && 1 == $_POST['delete'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   437
		$r = wp_delete_comment( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
	if ( $r ) // Decide if we need to send back '1' or a more complicated response including page links and comment counts
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
		_wp_ajax_delete_comment_response( $comment->comment_ID, $delta );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
	wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
function wp_ajax_delete_tag() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
	$tag_id = (int) $_POST['tag_ID'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
	check_ajax_referer( "delete-tag_$tag_id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
	$taxonomy = !empty($_POST['taxonomy']) ? $_POST['taxonomy'] : 'post_tag';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
	$tax = get_taxonomy($taxonomy);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
	if ( !current_user_can( $tax->cap->delete_terms ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
	$tag = get_term( $tag_id, $taxonomy );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
	if ( !$tag || is_wp_error( $tag ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
	if ( wp_delete_term($tag_id, $taxonomy))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
function wp_ajax_delete_link() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
	$id = isset( $_POST['id'] ) ? (int) $_POST['id'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
	check_ajax_referer( "delete-bookmark_$id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
	if ( !current_user_can( 'manage_links' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
	$link = get_bookmark( $id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
	if ( !$link || is_wp_error( $link ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
	if ( wp_delete_link( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
function wp_ajax_delete_meta() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
	$id = isset( $_POST['id'] ) ? (int) $_POST['id'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
	check_ajax_referer( "delete-meta_$id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
	if ( !$meta = get_metadata_by_mid( 'post', $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
	if ( is_protected_meta( $meta->meta_key, 'post' ) || ! current_user_can( 'delete_post_meta',  $meta->post_id, $meta->meta_key ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
	if ( delete_meta( $meta->meta_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
	wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
function wp_ajax_delete_post( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
		$action = 'delete-post';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
	$id = isset( $_POST['id'] ) ? (int) $_POST['id'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
	check_ajax_referer( "{$action}_$id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
	if ( !current_user_can( 'delete_post', $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
	if ( !get_post( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
	if ( wp_delete_post( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
function wp_ajax_trash_post( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
		$action = 'trash-post';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
	$id = isset( $_POST['id'] ) ? (int) $_POST['id'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
	check_ajax_referer( "{$action}_$id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
	if ( !current_user_can( 'delete_post', $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
	if ( !get_post( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
	if ( 'trash-post' == $action )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
		$done = wp_trash_post( $id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
		$done = wp_untrash_post( $id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
	if ( $done )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
	wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
function wp_ajax_untrash_post( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
		$action = 'untrash-post';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
	wp_ajax_trash_post( $action );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
function wp_ajax_delete_page( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
		$action = 'delete-page';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
	$id = isset( $_POST['id'] ) ? (int) $_POST['id'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
	check_ajax_referer( "{$action}_$id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
	if ( !current_user_can( 'delete_page', $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
	if ( ! get_post( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
	if ( wp_delete_post( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
function wp_ajax_dim_comment() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
	$id = isset( $_POST['id'] ) ? (int) $_POST['id'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
	if ( !$comment = get_comment( $id ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
		$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
			'what' => 'comment',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
			'id' => new WP_Error('invalid_comment', sprintf(__('Comment %d does not exist'), $id))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
		$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
	if ( ! current_user_can( 'edit_comment', $comment->comment_ID ) && ! current_user_can( 'moderate_comments' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
	$current = wp_get_comment_status( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
	if ( isset( $_POST['new'] ) && $_POST['new'] == $current )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
		wp_die( time() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
	check_ajax_referer( "approve-comment_$id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
	if ( in_array( $current, array( 'unapproved', 'spam' ) ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
		$result = wp_set_comment_status( $comment->comment_ID, 'approve', true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
		$result = wp_set_comment_status( $comment->comment_ID, 'hold', true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
	if ( is_wp_error($result) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
		$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
			'what' => 'comment',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
			'id' => $result
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
		$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
	// Decide if we need to send back '1' or a more complicated response including page links and comment counts
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
	_wp_ajax_delete_comment_response( $comment->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
	wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
function wp_ajax_add_link_category( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
		$action = 'add-link-category';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
	check_ajax_referer( $action );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
	if ( !current_user_can( 'manage_categories' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
	$names = explode(',', wp_unslash( $_POST['newcat'] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
	$x = new WP_Ajax_Response();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
	foreach ( $names as $cat_name ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
		$cat_name = trim($cat_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
		$slug = sanitize_title($cat_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
		if ( '' === $slug )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
		if ( !$cat_id = term_exists( $cat_name, 'link_category' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
			$cat_id = wp_insert_term( $cat_name, 'link_category' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
		if ( is_wp_error( $cat_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
		else if ( is_array( $cat_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
			$cat_id = $cat_id['term_id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
		$cat_name = esc_html( $cat_name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
		$x->add( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
			'what' => 'link-category',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
			'id' => $cat_id,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
			'data' => "<li id='link-category-$cat_id'><label for='in-link-category-$cat_id' class='selectit'><input value='" . esc_attr($cat_id) . "' type='checkbox' checked='checked' name='link_category[]' id='in-link-category-$cat_id'/> $cat_name</label></li>",
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
			'position' => -1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
function wp_ajax_add_tag() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
	global $wp_list_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
	check_ajax_referer( 'add-tag', '_wpnonce_add-tag' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
	$post_type = !empty($_POST['post_type']) ? $_POST['post_type'] : 'post';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
	$taxonomy = !empty($_POST['taxonomy']) ? $_POST['taxonomy'] : 'post_tag';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
	$tax = get_taxonomy($taxonomy);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
	if ( !current_user_can( $tax->cap->edit_terms ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
	$x = new WP_Ajax_Response();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
	$tag = wp_insert_term($_POST['tag-name'], $taxonomy, $_POST );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
	if ( !$tag || is_wp_error($tag) || (!$tag = get_term( $tag['term_id'], $taxonomy )) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
		$message = __('An error has occurred. Please reload the page and try again.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
		if ( is_wp_error($tag) && $tag->get_error_message() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
			$message = $tag->get_error_message();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
		$x->add( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
			'what' => 'taxonomy',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
			'data' => new WP_Error('error', $message )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
		$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
	$wp_list_table = _get_list_table( 'WP_Terms_List_Table', array( 'screen' => $_POST['screen'] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
	$level = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
	if ( is_taxonomy_hierarchical($taxonomy) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
		$level = count( get_ancestors( $tag->term_id, $taxonomy ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
		ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
		$wp_list_table->single_row( $tag, $level );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
		$noparents = ob_get_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
	ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
	$wp_list_table->single_row( $tag );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
	$parents = ob_get_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
	$x->add( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
		'what' => 'taxonomy',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
		'supplemental' => compact('parents', 'noparents')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
	$x->add( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
		'what' => 'term',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
		'position' => $level,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
		'supplemental' => (array) $tag
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
function wp_ajax_get_tagcloud() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
	if ( isset( $_POST['tax'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
		$taxonomy = sanitize_key( $_POST['tax'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
		$tax = get_taxonomy( $taxonomy );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
		if ( ! $tax )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   688
			wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
		if ( ! current_user_can( $tax->cap->assign_terms ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
			wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
	$tags = get_terms( $taxonomy, array( 'number' => 45, 'orderby' => 'count', 'order' => 'DESC' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
	if ( empty( $tags ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
		wp_die( $tax->labels->not_found );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
	if ( is_wp_error( $tags ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
		wp_die( $tags->get_error_message() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
	foreach ( $tags as $key => $tag ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
		$tags[ $key ]->link = '#';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
		$tags[ $key ]->id = $tag->term_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
	// We need raw tag names here, so don't filter the output
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
	$return = wp_generate_tag_cloud( $tags, array('filter' => 0) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
	if ( empty($return) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
	echo $return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
function wp_ajax_get_comments( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
	global $wp_list_table, $post_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
		$action = 'get-comments';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
	check_ajax_referer( $action );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
	if ( empty( $post_id ) && ! empty( $_REQUEST['p'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
		$id = absint( $_REQUEST['p'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
		if ( ! empty( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
			$post_id = $id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
	if ( empty( $post_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
	$wp_list_table = _get_list_table( 'WP_Post_Comments_List_Table', array( 'screen' => 'edit-comments' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
	if ( ! current_user_can( 'edit_post', $post_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
	$wp_list_table->prepare_items();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
	if ( !$wp_list_table->has_items() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
	$x = new WP_Ajax_Response();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
	ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
	foreach ( $wp_list_table->items as $comment ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
		if ( ! current_user_can( 'edit_comment', $comment->comment_ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
		get_comment( $comment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
		$wp_list_table->single_row( $comment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
	$comment_list_item = ob_get_contents();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
	ob_end_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
	$x->add( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
		'what' => 'comments',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
		'data' => $comment_list_item
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
	) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
function wp_ajax_replyto_comment( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
	global $wp_list_table, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
		$action = 'replyto-comment';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
	check_ajax_referer( $action, '_ajax_nonce-replyto-comment' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
	$comment_post_ID = (int) $_POST['comment_post_ID'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
	$post = get_post( $comment_post_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
	if ( ! $post )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
	if ( !current_user_can( 'edit_post', $comment_post_ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
	if ( empty( $post->post_status ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
	elseif ( in_array($post->post_status, array('draft', 'pending', 'trash') ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
		wp_die( __('ERROR: you are replying to a comment on a draft post.') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
	$user = wp_get_current_user();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
	if ( $user->exists() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
		$user_ID = $user->ID;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
		$comment_author       = wp_slash( $user->display_name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
		$comment_author_email = wp_slash( $user->user_email );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
		$comment_author_url   = wp_slash( $user->user_url );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
		$comment_content      = trim($_POST['content']);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
		if ( current_user_can( 'unfiltered_html' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
			if ( ! isset( $_POST['_wp_unfiltered_html_comment'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
				$_POST['_wp_unfiltered_html_comment'] = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
			if ( wp_create_nonce( 'unfiltered-html-comment' ) != $_POST['_wp_unfiltered_html_comment'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
				kses_remove_filters(); // start with a clean slate
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
				kses_init_filters(); // set up the filters
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
		wp_die( __( 'Sorry, you must be logged in to reply to a comment.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
	if ( '' == $comment_content )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
		wp_die( __( 'ERROR: please type a comment.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
	$comment_parent = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
	if ( isset( $_POST['comment_ID'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   808
		$comment_parent = absint( $_POST['comment_ID'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
	$comment_auto_approved = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
	$commentdata = compact('comment_post_ID', 'comment_author', 'comment_author_email', 'comment_author_url', 'comment_content', 'comment_type', 'comment_parent', 'user_ID');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
	// automatically approve parent comment
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
	if ( !empty($_POST['approve_parent']) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
		$parent = get_comment( $comment_parent );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
		if ( $parent && $parent->comment_approved === '0' && $parent->comment_post_ID == $comment_post_ID ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
			if ( wp_set_comment_status( $parent->comment_ID, 'approve' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
				$comment_auto_approved = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
	$comment_id = wp_new_comment( $commentdata );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
	$comment = get_comment($comment_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
	if ( ! $comment ) wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
	$position = ( isset($_POST['position']) && (int) $_POST['position'] ) ? (int) $_POST['position'] : '-1';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
	ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
	if ( isset( $_REQUEST['mode'] ) && 'dashboard' == $_REQUEST['mode'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
		require_once( ABSPATH . 'wp-admin/includes/dashboard.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
		_wp_dashboard_recent_comments_row( $comment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
		if ( isset( $_REQUEST['mode'] ) && 'single' == $_REQUEST['mode'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   834
			$wp_list_table = _get_list_table('WP_Post_Comments_List_Table', array( 'screen' => 'edit-comments' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
			$wp_list_table = _get_list_table('WP_Comments_List_Table', array( 'screen' => 'edit-comments' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
		$wp_list_table->single_row( $comment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
	$comment_list_item = ob_get_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
	$response =  array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
		'what' => 'comment',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
		'id' => $comment->comment_ID,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
		'data' => $comment_list_item,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
		'position' => $position
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
	);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
	if ( $comment_auto_approved )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
		$response['supplemental'] = array( 'parent_approved' => $parent->comment_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
	$x = new WP_Ajax_Response();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
	$x->add( $response );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
function wp_ajax_edit_comment() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
	global $wp_list_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
	check_ajax_referer( 'replyto-comment', '_ajax_nonce-replyto-comment' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
	$comment_id = (int) $_POST['comment_ID'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
	if ( ! current_user_can( 'edit_comment', $comment_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
	if ( '' == $_POST['content'] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
		wp_die( __( 'ERROR: please type a comment.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
	if ( isset( $_POST['status'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
		$_POST['comment_status'] = $_POST['status'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
	edit_comment();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
	$position = ( isset($_POST['position']) && (int) $_POST['position']) ? (int) $_POST['position'] : '-1';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
	$comments_status = isset($_POST['comments_listing']) ? $_POST['comments_listing'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
	$checkbox = ( isset($_POST['checkbox']) && true == $_POST['checkbox'] ) ? 1 : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
	$wp_list_table = _get_list_table( $checkbox ? 'WP_Comments_List_Table' : 'WP_Post_Comments_List_Table', array( 'screen' => 'edit-comments' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
	$comment = get_comment( $comment_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
	if ( empty( $comment->comment_ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
	ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
	$wp_list_table->single_row( $comment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
	$comment_list_item = ob_get_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
	$x = new WP_Ajax_Response();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
	$x->add( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
		'what' => 'edit_comment',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
		'id' => $comment->comment_ID,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
		'data' => $comment_list_item,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
		'position' => $position
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
	));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
function wp_ajax_add_menu_item() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
	check_ajax_referer( 'add-menu_item', 'menu-settings-column-nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
	if ( ! current_user_can( 'edit_theme_options' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
	require_once ABSPATH . 'wp-admin/includes/nav-menu.php';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
	// For performance reasons, we omit some object properties from the checklist.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
	// The following is a hacky way to restore them when adding non-custom items.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
	$menu_items_data = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
	foreach ( (array) $_POST['menu-item'] as $menu_item_data ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
		if (
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
			! empty( $menu_item_data['menu-item-type'] ) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
			'custom' != $menu_item_data['menu-item-type'] &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
			! empty( $menu_item_data['menu-item-object-id'] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
		) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
			switch( $menu_item_data['menu-item-type'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
				case 'post_type' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
					$_object = get_post( $menu_item_data['menu-item-object-id'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   920
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
				case 'taxonomy' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
					$_object = get_term( $menu_item_data['menu-item-object-id'], $menu_item_data['menu-item-object'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
			$_menu_items = array_map( 'wp_setup_nav_menu_item', array( $_object ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
			$_menu_item = array_shift( $_menu_items );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   929
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
			// Restore the missing menu item properties
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
			$menu_item_data['menu-item-description'] = $_menu_item->description;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
		$menu_items_data[] = $menu_item_data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
	$item_ids = wp_save_nav_menu_items( 0, $menu_items_data );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
	if ( is_wp_error( $item_ids ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   940
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   941
	$menu_items = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   942
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   943
	foreach ( (array) $item_ids as $menu_item_id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   944
		$menu_obj = get_post( $menu_item_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
		if ( ! empty( $menu_obj->ID ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
			$menu_obj = wp_setup_nav_menu_item( $menu_obj );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
			$menu_obj->label = $menu_obj->title; // don't show "(pending)" in ajax-added items
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   948
			$menu_items[] = $menu_obj;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   949
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
	 * Filter the Walker class used when adding nav menu items.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   957
	 * @param string $class   The walker class to use. Default 'Walker_Nav_Menu_Edit'.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   958
	 * @param int    $menu_id The menu id, derived from $_POST['menu'].
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
	$walker_class_name = apply_filters( 'wp_edit_nav_menu_walker', 'Walker_Nav_Menu_Edit', $_POST['menu'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   961
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   962
	if ( ! class_exists( $walker_class_name ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   963
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   964
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   965
	if ( ! empty( $menu_items ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
		$args = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   967
			'after' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   968
			'before' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
			'link_after' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
			'link_before' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   971
			'walker' => new $walker_class_name,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   972
		);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
		echo walk_nav_menu_tree( $menu_items, 0, (object) $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   974
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   975
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   978
function wp_ajax_add_meta() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   979
	check_ajax_referer( 'add-meta', '_ajax_nonce-add-meta' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
	$c = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
	$pid = (int) $_POST['post_id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
	$post = get_post( $pid );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   984
	if ( isset($_POST['metakeyselect']) || isset($_POST['metakeyinput']) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   985
		if ( !current_user_can( 'edit_post', $pid ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   986
			wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   987
		if ( isset($_POST['metakeyselect']) && '#NONE#' == $_POST['metakeyselect'] && empty($_POST['metakeyinput']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   988
			wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   989
		if ( $post->post_status == 'auto-draft' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
			$save_POST = $_POST; // Backup $_POST
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
			$_POST = array(); // Make it empty for edit_post()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   992
			$_POST['action'] = 'draft'; // Warning fix
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   993
			$_POST['post_ID'] = $pid;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   994
			$_POST['post_type'] = $post->post_type;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
			$_POST['post_status'] = 'draft';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   996
			$now = current_time('timestamp', 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   997
			$_POST['post_title'] = sprintf( __( 'Draft created on %1$s at %2$s' ), date( get_option( 'date_format' ), $now ), date( get_option( 'time_format' ), $now ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   998
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   999
			if ( $pid = edit_post() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1000
				if ( is_wp_error( $pid ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1001
					$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1002
						'what' => 'meta',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1003
						'data' => $pid
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1004
					) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1005
					$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1006
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1007
				$_POST = $save_POST; // Now we can restore original $_POST again
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1008
				if ( !$mid = add_meta( $pid ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
					wp_die( __( 'Please provide a custom field value.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
			} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
				wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
		} else if ( !$mid = add_meta( $pid ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
			wp_die( __( 'Please provide a custom field value.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1015
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
		$meta = get_metadata_by_mid( 'post', $mid );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1018
		$pid = (int) $meta->post_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1019
		$meta = get_object_vars( $meta );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1020
		$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1021
			'what' => 'meta',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1022
			'id' => $mid,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1023
			'data' => _list_meta_row( $meta, $c ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1024
			'position' => 1,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
			'supplemental' => array('postid' => $pid)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1026
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1027
	} else { // Update?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1028
		$mid = (int) key( $_POST['meta'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1029
		$key = wp_unslash( $_POST['meta'][$mid]['key'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1030
		$value = wp_unslash( $_POST['meta'][$mid]['value'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1031
		if ( '' == trim($key) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1032
			wp_die( __( 'Please provide a custom field name.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1033
		if ( '' == trim($value) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1034
			wp_die( __( 'Please provide a custom field value.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1035
		if ( ! $meta = get_metadata_by_mid( 'post', $mid ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1036
			wp_die( 0 ); // if meta doesn't exist
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1037
		if ( is_protected_meta( $meta->meta_key, 'post' ) || is_protected_meta( $key, 'post' ) ||
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1038
			! current_user_can( 'edit_post_meta', $meta->post_id, $meta->meta_key ) ||
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1039
			! current_user_can( 'edit_post_meta', $meta->post_id, $key ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1040
			wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
		if ( $meta->meta_value != $value || $meta->meta_key != $key ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1042
			if ( !$u = update_metadata_by_mid( 'post', $mid, $value, $key ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1043
				wp_die( 0 ); // We know meta exists; we also know it's unchanged (or DB error, in which case there are bigger problems).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1046
		$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1047
			'what' => 'meta',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1048
			'id' => $mid, 'old_id' => $mid,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1049
			'data' => _list_meta_row( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1050
				'meta_key' => $key,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1051
				'meta_value' => $value,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1052
				'meta_id' => $mid
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1053
			), $c ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1054
			'position' => 0,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1055
			'supplemental' => array('postid' => $meta->post_id)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1056
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1057
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1058
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1059
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1060
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1061
function wp_ajax_add_user( $action ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1062
	global $wp_list_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1063
	if ( empty( $action ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1064
		$action = 'add-user';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1065
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1066
	check_ajax_referer( $action );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1067
	if ( ! current_user_can('create_users') )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1068
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1069
	if ( ! $user_id = edit_user() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1070
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1071
	} elseif ( is_wp_error( $user_id ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1072
		$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1073
			'what' => 'user',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1074
			'id' => $user_id
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1075
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1076
		$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1077
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1078
	$user_object = get_userdata( $user_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1079
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1080
	$wp_list_table = _get_list_table('WP_Users_List_Table');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1081
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1082
	$role = current( $user_object->roles );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1083
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1084
	$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1085
		'what' => 'user',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1086
		'id' => $user_id,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1087
		'data' => $wp_list_table->single_row( $user_object, '', $role ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1088
		'supplemental' => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1089
			'show-link' => sprintf(__( 'User <a href="#%s">%s</a> added' ), "user-$user_id", $user_object->user_login),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1090
			'role' => $role,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1091
		)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1092
	) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1093
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1094
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1095
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1096
function wp_ajax_autosave() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1097
	define( 'DOING_AUTOSAVE', true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1098
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1099
	check_ajax_referer( 'autosave', 'autosavenonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1100
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1101
	if ( ! empty( $_POST['catslist'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1102
		$_POST['post_category'] = explode( ',', $_POST['catslist'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1103
	if ( $_POST['post_type'] == 'page' || empty( $_POST['post_category'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1104
		unset( $_POST['post_category'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1105
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1106
	$data = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1107
	$supplemental = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1108
	$id = $revision_id = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1109
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1110
	$post_id = (int) $_POST['post_id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1111
	$_POST['ID'] = $_POST['post_ID'] = $post_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1112
	$post = get_post( $post_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1113
	if ( empty( $post->ID ) || ! current_user_can( 'edit_post', $post->ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1114
		wp_die( __( 'You are not allowed to edit this post.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1115
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1116
	if ( 'page' == $post->post_type && ! current_user_can( 'edit_page', $post->ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1117
		wp_die( __( 'You are not allowed to edit this page.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1118
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1119
	if ( 'auto-draft' == $post->post_status )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1120
		$_POST['post_status'] = 'draft';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1121
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1122
	if ( ! empty( $_POST['autosave'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1123
		if ( ! wp_check_post_lock( $post->ID ) && get_current_user_id() == $post->post_author && ( 'auto-draft' == $post->post_status || 'draft' == $post->post_status ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1124
			// Drafts and auto-drafts are just overwritten by autosave for the same user if the post is not locked
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1125
			$id = edit_post();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1126
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1127
			// Non drafts or other users drafts are not overwritten. The autosave is stored in a special post revision for each user.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1128
			$revision_id = wp_create_post_autosave( $post->ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1129
			if ( is_wp_error($revision_id) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1130
				$id = $revision_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1131
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1132
				$id = $post->ID;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1133
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1134
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1135
		if ( ! is_wp_error($id) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1136
			/* translators: draft saved date format, see http://php.net/date */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1137
			$draft_saved_date_format = __('g:i:s a');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1138
			/* translators: %s: date and time */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1139
			$data = sprintf( __('Draft saved at %s.'), date_i18n( $draft_saved_date_format ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1140
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1141
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1142
		if ( ! empty( $_POST['auto_draft'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1143
			$id = 0; // This tells us it didn't actually save
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1144
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1145
			$id = $post->ID;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1146
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1147
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1148
	// @todo Consider exposing any errors, rather than having 'Saving draft...'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1149
	$x = new WP_Ajax_Response( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1150
		'what' => 'autosave',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1151
		'id' => $id,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1152
		'data' => $data,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1153
		'supplemental' => $supplemental
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1154
	) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1155
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1156
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1157
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1158
function wp_ajax_closed_postboxes() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1159
	check_ajax_referer( 'closedpostboxes', 'closedpostboxesnonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1160
	$closed = isset( $_POST['closed'] ) ? explode( ',', $_POST['closed']) : array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1161
	$closed = array_filter($closed);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1162
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1163
	$hidden = isset( $_POST['hidden'] ) ? explode( ',', $_POST['hidden']) : array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1164
	$hidden = array_filter($hidden);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1165
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1166
	$page = isset( $_POST['page'] ) ? $_POST['page'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1167
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1168
	if ( $page != sanitize_key( $page ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1169
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1170
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1171
	if ( ! $user = wp_get_current_user() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1172
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1173
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1174
	if ( is_array($closed) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1175
		update_user_option($user->ID, "closedpostboxes_$page", $closed, true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1176
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1177
	if ( is_array($hidden) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1178
		$hidden = array_diff( $hidden, array('submitdiv', 'linksubmitdiv', 'manage-menu', 'create-menu') ); // postboxes that are always shown
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1179
		update_user_option($user->ID, "metaboxhidden_$page", $hidden, true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1180
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1181
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1182
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1183
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1184
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1185
function wp_ajax_hidden_columns() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1186
	check_ajax_referer( 'screen-options-nonce', 'screenoptionnonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1187
	$hidden = isset( $_POST['hidden'] ) ? $_POST['hidden'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1188
	$hidden = explode( ',', $_POST['hidden'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1189
	$page = isset( $_POST['page'] ) ? $_POST['page'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1190
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1191
	if ( $page != sanitize_key( $page ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1192
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1193
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1194
	if ( ! $user = wp_get_current_user() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1195
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1196
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1197
	if ( is_array($hidden) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1198
		update_user_option($user->ID, "manage{$page}columnshidden", $hidden, true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1199
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1200
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1201
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1202
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1203
function wp_ajax_update_welcome_panel() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1204
	check_ajax_referer( 'welcome-panel-nonce', 'welcomepanelnonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1205
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1206
	if ( ! current_user_can( 'edit_theme_options' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1207
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1208
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1209
	update_user_meta( get_current_user_id(), 'show_welcome_panel', empty( $_POST['visible'] ) ? 0 : 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1210
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1211
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1212
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1213
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1214
function wp_ajax_menu_get_metabox() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1215
	if ( ! current_user_can( 'edit_theme_options' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1216
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1217
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1218
	require_once ABSPATH . 'wp-admin/includes/nav-menu.php';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1219
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1220
	if ( isset( $_POST['item-type'] ) && 'post_type' == $_POST['item-type'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1221
		$type = 'posttype';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1222
		$callback = 'wp_nav_menu_item_post_type_meta_box';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1223
		$items = (array) get_post_types( array( 'show_in_nav_menus' => true ), 'object' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1224
	} elseif ( isset( $_POST['item-type'] ) && 'taxonomy' == $_POST['item-type'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1225
		$type = 'taxonomy';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1226
		$callback = 'wp_nav_menu_item_taxonomy_meta_box';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1227
		$items = (array) get_taxonomies( array( 'show_ui' => true ), 'object' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1228
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1229
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1230
	if ( ! empty( $_POST['item-object'] ) && isset( $items[$_POST['item-object']] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1231
		$menus_meta_box_object = $items[ $_POST['item-object'] ];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1232
		/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1233
		 * Filter a nav menu meta box object.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1234
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1235
		 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1236
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1237
		 * @param object $menus_meta_box_object A nav menu meta box object, such as Page, Post, Category, Tag, etc.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1238
		 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1239
		$item = apply_filters( 'nav_menu_meta_box_object', $menus_meta_box_object );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1240
		ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1241
		call_user_func_array($callback, array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1242
			null,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1243
			array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1244
				'id' => 'add-' . $item->name,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1245
				'title' => $item->labels->name,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1246
				'callback' => $callback,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1247
				'args' => $item,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1248
			)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1249
		));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1250
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1251
		$markup = ob_get_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1252
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1253
		echo json_encode(array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1254
			'replace-id' => $type . '-' . $item->name,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1255
			'markup' => $markup,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1256
		));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1257
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1258
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1259
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1260
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1261
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1262
function wp_ajax_wp_link_ajax() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1263
	check_ajax_referer( 'internal-linking', '_ajax_linking_nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1264
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1265
	$args = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1266
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1267
	if ( isset( $_POST['search'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1268
		$args['s'] = wp_unslash( $_POST['search'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1269
	$args['pagenum'] = ! empty( $_POST['page'] ) ? absint( $_POST['page'] ) : 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1270
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1271
	require(ABSPATH . WPINC . '/class-wp-editor.php');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1272
	$results = _WP_Editors::wp_link_query( $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1273
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1274
	if ( ! isset( $results ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1275
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1276
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1277
	echo json_encode( $results );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1278
	echo "\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1279
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1280
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1281
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1282
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1283
function wp_ajax_menu_locations_save() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1284
	if ( ! current_user_can( 'edit_theme_options' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1285
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1286
	check_ajax_referer( 'add-menu_item', 'menu-settings-column-nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1287
	if ( ! isset( $_POST['menu-locations'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1288
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1289
	set_theme_mod( 'nav_menu_locations', array_map( 'absint', $_POST['menu-locations'] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1290
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1291
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1292
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1293
function wp_ajax_meta_box_order() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1294
	check_ajax_referer( 'meta-box-order' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1295
	$order = isset( $_POST['order'] ) ? (array) $_POST['order'] : false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1296
	$page_columns = isset( $_POST['page_columns'] ) ? $_POST['page_columns'] : 'auto';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1297
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1298
	if ( $page_columns != 'auto' )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1299
		$page_columns = (int) $page_columns;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1300
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1301
	$page = isset( $_POST['page'] ) ? $_POST['page'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1302
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1303
	if ( $page != sanitize_key( $page ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1304
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1305
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1306
	if ( ! $user = wp_get_current_user() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1307
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1308
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1309
	if ( $order )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1310
		update_user_option($user->ID, "meta-box-order_$page", $order, true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1311
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1312
	if ( $page_columns )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1313
		update_user_option($user->ID, "screen_layout_$page", $page_columns, true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1314
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1315
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1316
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1317
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1318
function wp_ajax_menu_quick_search() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1319
	if ( ! current_user_can( 'edit_theme_options' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1320
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1321
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1322
	require_once ABSPATH . 'wp-admin/includes/nav-menu.php';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1323
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1324
	_wp_ajax_menu_quick_search( $_POST );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1325
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1326
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1327
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1328
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1329
function wp_ajax_get_permalink() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1330
	check_ajax_referer( 'getpermalink', 'getpermalinknonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1331
	$post_id = isset($_POST['post_id'])? intval($_POST['post_id']) : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1332
	wp_die( add_query_arg( array( 'preview' => 'true' ), get_permalink( $post_id ) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1333
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1334
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1335
function wp_ajax_sample_permalink() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1336
	check_ajax_referer( 'samplepermalink', 'samplepermalinknonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1337
	$post_id = isset($_POST['post_id'])? intval($_POST['post_id']) : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1338
	$title = isset($_POST['new_title'])? $_POST['new_title'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1339
	$slug = isset($_POST['new_slug'])? $_POST['new_slug'] : null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1340
	wp_die( get_sample_permalink_html( $post_id, $title, $slug ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1341
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1342
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1343
function wp_ajax_inline_save() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1344
	global $wp_list_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1345
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1346
	check_ajax_referer( 'inlineeditnonce', '_inline_edit' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1347
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1348
	if ( ! isset($_POST['post_ID']) || ! ( $post_ID = (int) $_POST['post_ID'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1349
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1350
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1351
	if ( 'page' == $_POST['post_type'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1352
		if ( ! current_user_can( 'edit_page', $post_ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1353
			wp_die( __( 'You are not allowed to edit this page.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1354
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1355
		if ( ! current_user_can( 'edit_post', $post_ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1356
			wp_die( __( 'You are not allowed to edit this post.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1357
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1358
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1359
	if ( $last = wp_check_post_lock( $post_ID ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1360
		$last_user = get_userdata( $last );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1361
		$last_user_name = $last_user ? $last_user->display_name : __( 'Someone' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1362
		printf( $_POST['post_type'] == 'page' ? __( 'Saving is disabled: %s is currently editing this page.' ) : __( 'Saving is disabled: %s is currently editing this post.' ),	esc_html( $last_user_name ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1363
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1364
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1365
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1366
	$data = &$_POST;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1367
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1368
	$post = get_post( $post_ID, ARRAY_A );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1369
	$post = wp_slash($post); //since it is from db
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1370
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1371
	$data['content'] = $post['post_content'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1372
	$data['excerpt'] = $post['post_excerpt'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1373
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1374
	// rename
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1375
	$data['user_ID'] = get_current_user_id();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1376
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1377
	if ( isset($data['post_parent']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1378
		$data['parent_id'] = $data['post_parent'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1379
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1380
	// status
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1381
	if ( isset($data['keep_private']) && 'private' == $data['keep_private'] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1382
		$data['post_status'] = 'private';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1383
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1384
		$data['post_status'] = $data['_status'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1385
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1386
	if ( empty($data['comment_status']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1387
		$data['comment_status'] = 'closed';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1388
	if ( empty($data['ping_status']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1389
		$data['ping_status'] = 'closed';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1390
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1391
	// Hack: wp_unique_post_slug() doesn't work for drafts, so we will fake that our post is published.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1392
	if ( ! empty( $data['post_name'] ) && in_array( $post['post_status'], array( 'draft', 'pending' ) ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1393
		$post['post_status'] = 'publish';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1394
		$data['post_name'] = wp_unique_post_slug( $data['post_name'], $post['ID'], $post['post_status'], $post['post_type'], $post['post_parent'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1395
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1396
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1397
	// update the post
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1398
	edit_post();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1399
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1400
	$wp_list_table = _get_list_table( 'WP_Posts_List_Table', array( 'screen' => $_POST['screen'] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1401
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1402
	$mode = $_POST['post_view'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1403
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1404
	$level = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1405
	$request_post = array( get_post( $_POST['post_ID'] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1406
	$parent = $request_post[0]->post_parent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1407
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1408
	while ( $parent > 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1409
		$parent_post = get_post( $parent );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1410
		$parent = $parent_post->post_parent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1411
		$level++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1412
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1413
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1414
	$wp_list_table->display_rows( array( get_post( $_POST['post_ID'] ) ), $level );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1415
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1416
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1417
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1418
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1419
function wp_ajax_inline_save_tax() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1420
	global $wp_list_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1421
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1422
	check_ajax_referer( 'taxinlineeditnonce', '_inline_edit' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1423
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1424
	$taxonomy = sanitize_key( $_POST['taxonomy'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1425
	$tax = get_taxonomy( $taxonomy );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1426
	if ( ! $tax )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1427
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1428
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1429
	if ( ! current_user_can( $tax->cap->edit_terms ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1430
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1431
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1432
	$wp_list_table = _get_list_table( 'WP_Terms_List_Table', array( 'screen' => 'edit-' . $taxonomy ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1433
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1434
	if ( ! isset($_POST['tax_ID']) || ! ( $id = (int) $_POST['tax_ID'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1435
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1436
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1437
	$tag = get_term( $id, $taxonomy );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1438
	$_POST['description'] = $tag->description;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1439
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1440
	$updated = wp_update_term($id, $taxonomy, $_POST);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1441
	if ( $updated && !is_wp_error($updated) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1442
		$tag = get_term( $updated['term_id'], $taxonomy );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1443
		if ( !$tag || is_wp_error( $tag ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1444
			if ( is_wp_error($tag) && $tag->get_error_message() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1445
				wp_die( $tag->get_error_message() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1446
			wp_die( __( 'Item not updated.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1447
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1448
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1449
		if ( is_wp_error($updated) && $updated->get_error_message() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1450
			wp_die( $updated->get_error_message() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1451
		wp_die( __( 'Item not updated.' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1452
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1453
	$level = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1454
	$parent = $tag->parent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1455
	while ( $parent > 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1456
		$parent_tag = get_term( $parent, $taxonomy );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1457
		$parent = $parent_tag->parent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1458
		$level++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1459
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1460
	$wp_list_table->single_row( $tag, $level );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1461
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1462
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1463
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1464
function wp_ajax_find_posts() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1465
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1466
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1467
	check_ajax_referer( 'find-posts' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1468
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1469
	$post_types = get_post_types( array( 'public' => true ), 'objects' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1470
	unset( $post_types['attachment'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1471
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1472
	$s = wp_unslash( $_POST['ps'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1473
	$searchand = $search = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1474
	$args = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1475
		'post_type' => array_keys( $post_types ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1476
		'post_status' => 'any',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1477
		'posts_per_page' => 50,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1478
	);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1479
	if ( '' !== $s )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1480
		$args['s'] = $s;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1481
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1482
	$posts = get_posts( $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1483
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1484
	if ( ! $posts )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1485
		wp_die( __('No items found.') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1486
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1487
	$html = '<table class="widefat" cellspacing="0"><thead><tr><th class="found-radio"><br /></th><th>'.__('Title').'</th><th class="no-break">'.__('Type').'</th><th class="no-break">'.__('Date').'</th><th class="no-break">'.__('Status').'</th></tr></thead><tbody>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1488
	foreach ( $posts as $post ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1489
		$title = trim( $post->post_title ) ? $post->post_title : __( '(no title)' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1490
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1491
		switch ( $post->post_status ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1492
			case 'publish' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1493
			case 'private' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1494
				$stat = __('Published');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1495
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1496
			case 'future' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1497
				$stat = __('Scheduled');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1498
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1499
			case 'pending' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1500
				$stat = __('Pending Review');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1501
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1502
			case 'draft' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1503
				$stat = __('Draft');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1504
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1505
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1506
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1507
		if ( '0000-00-00 00:00:00' == $post->post_date ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1508
			$time = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1509
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1510
			/* translators: date format in table columns, see http://php.net/date */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1511
			$time = mysql2date(__('Y/m/d'), $post->post_date);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1512
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1513
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1514
		$html .= '<tr class="found-posts"><td class="found-radio"><input type="radio" id="found-'.$post->ID.'" name="found_post_id" value="' . esc_attr($post->ID) . '"></td>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1515
		$html .= '<td><label for="found-'.$post->ID.'">' . esc_html( $title ) . '</label></td><td class="no-break">' . esc_html( $post_types[$post->post_type]->labels->singular_name ) . '</td><td class="no-break">'.esc_html( $time ) . '</td><td class="no-break">' . esc_html( $stat ). ' </td></tr>' . "\n\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1516
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1517
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1518
	$html .= '</tbody></table>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1519
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1520
	$x = new WP_Ajax_Response();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1521
	$x->add( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1522
		'data' => $html
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1523
	));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1524
	$x->send();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1525
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1526
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1527
function wp_ajax_widgets_order() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1528
	check_ajax_referer( 'save-sidebar-widgets', 'savewidgets' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1529
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1530
	if ( !current_user_can('edit_theme_options') )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1531
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1532
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1533
	unset( $_POST['savewidgets'], $_POST['action'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1534
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1535
	// save widgets order for all sidebars
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1536
	if ( is_array($_POST['sidebars']) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1537
		$sidebars = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1538
		foreach ( $_POST['sidebars'] as $key => $val ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1539
			$sb = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1540
			if ( !empty($val) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1541
				$val = explode(',', $val);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1542
				foreach ( $val as $k => $v ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1543
					if ( strpos($v, 'widget-') === false )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1544
						continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1545
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1546
					$sb[$k] = substr($v, strpos($v, '_') + 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1547
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1548
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1549
			$sidebars[$key] = $sb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1550
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1551
		wp_set_sidebars_widgets($sidebars);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1552
		wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1553
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1554
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1555
	wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1556
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1557
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1558
function wp_ajax_save_widget() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1559
	global $wp_registered_widgets, $wp_registered_widget_controls, $wp_registered_widget_updates;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1560
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1561
	check_ajax_referer( 'save-sidebar-widgets', 'savewidgets' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1562
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1563
	if ( !current_user_can('edit_theme_options') || !isset($_POST['id_base']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1564
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1565
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1566
	unset( $_POST['savewidgets'], $_POST['action'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1567
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1568
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1569
	 * Fires early when editing the widgets displayed in sidebars.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1570
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1571
	 * @since 2.8.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1572
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1573
	do_action( 'load-widgets.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1574
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1575
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1576
	 * Fires early when editing the widgets displayed in sidebars.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1577
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1578
	 * @since 2.8.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1579
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1580
	do_action( 'widgets.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1581
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1582
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1583
	 * Fires early when editing the widgets displayed in sidebars.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1584
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1585
	 * @since 2.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1586
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1587
	do_action( 'sidebar_admin_setup' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1588
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1589
	$id_base = $_POST['id_base'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1590
	$widget_id = $_POST['widget-id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1591
	$sidebar_id = $_POST['sidebar'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1592
	$multi_number = !empty($_POST['multi_number']) ? (int) $_POST['multi_number'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1593
	$settings = isset($_POST['widget-' . $id_base]) && is_array($_POST['widget-' . $id_base]) ? $_POST['widget-' . $id_base] : false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1594
	$error = '<p>' . __('An error has occurred. Please reload the page and try again.') . '</p>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1595
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1596
	$sidebars = wp_get_sidebars_widgets();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1597
	$sidebar = isset($sidebars[$sidebar_id]) ? $sidebars[$sidebar_id] : array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1598
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1599
	// delete
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1600
	if ( isset($_POST['delete_widget']) && $_POST['delete_widget'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1601
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1602
		if ( !isset($wp_registered_widgets[$widget_id]) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1603
			wp_die( $error );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1604
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1605
		$sidebar = array_diff( $sidebar, array($widget_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1606
		$_POST = array('sidebar' => $sidebar_id, 'widget-' . $id_base => array(), 'the-widget-id' => $widget_id, 'delete_widget' => '1');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1607
	} elseif ( $settings && preg_match( '/__i__|%i%/', key($settings) ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1608
		if ( !$multi_number )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1609
			wp_die( $error );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1610
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1611
		$_POST['widget-' . $id_base] = array( $multi_number => array_shift($settings) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1612
		$widget_id = $id_base . '-' . $multi_number;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1613
		$sidebar[] = $widget_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1614
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1615
	$_POST['widget-id'] = $sidebar;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1616
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1617
	foreach ( (array) $wp_registered_widget_updates as $name => $control ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1618
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1619
		if ( $name == $id_base ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1620
			if ( !is_callable( $control['callback'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1621
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1622
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1623
			ob_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1624
				call_user_func_array( $control['callback'], $control['params'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1625
			ob_end_clean();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1626
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1627
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1628
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1629
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1630
	if ( isset($_POST['delete_widget']) && $_POST['delete_widget'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1631
		$sidebars[$sidebar_id] = $sidebar;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1632
		wp_set_sidebars_widgets($sidebars);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1633
		echo "deleted:$widget_id";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1634
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1635
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1636
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1637
	if ( !empty($_POST['add_new']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1638
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1639
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1640
	if ( $form = $wp_registered_widget_controls[$widget_id] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1641
		call_user_func_array( $form['callback'], $form['params'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1642
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1643
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1644
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1645
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1646
function wp_ajax_upload_attachment() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1647
	check_ajax_referer( 'media-form' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1648
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1649
	if ( ! current_user_can( 'upload_files' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1650
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1651
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1652
	if ( isset( $_REQUEST['post_id'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1653
		$post_id = $_REQUEST['post_id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1654
		if ( ! current_user_can( 'edit_post', $post_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1655
			wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1656
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1657
		$post_id = null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1658
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1659
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1660
	$post_data = isset( $_REQUEST['post_data'] ) ? $_REQUEST['post_data'] : array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1661
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1662
	// If the context is custom header or background, make sure the uploaded file is an image.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1663
	if ( isset( $post_data['context'] ) && in_array( $post_data['context'], array( 'custom-header', 'custom-background' ) ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1664
		$wp_filetype = wp_check_filetype_and_ext( $_FILES['async-upload']['tmp_name'], $_FILES['async-upload']['name'], false );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1665
		if ( ! wp_match_mime_types( 'image', $wp_filetype['type'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1666
			echo json_encode( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1667
				'success' => false,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1668
				'data'    => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1669
					'message'  => __( 'The uploaded file is not a valid image. Please try again.' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1670
					'filename' => $_FILES['async-upload']['name'],
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1671
				)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1672
			) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1673
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1674
			wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1675
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1676
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1677
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1678
	$attachment_id = media_handle_upload( 'async-upload', $post_id, $post_data );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1679
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1680
	if ( is_wp_error( $attachment_id ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1681
		echo json_encode( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1682
			'success' => false,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1683
			'data'    => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1684
				'message'  => $attachment_id->get_error_message(),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1685
				'filename' => $_FILES['async-upload']['name'],
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1686
			)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1687
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1688
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1689
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1690
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1691
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1692
	if ( isset( $post_data['context'] ) && isset( $post_data['theme'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1693
		if ( 'custom-background' === $post_data['context'] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1694
			update_post_meta( $attachment_id, '_wp_attachment_is_custom_background', $post_data['theme'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1695
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1696
		if ( 'custom-header' === $post_data['context'] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1697
			update_post_meta( $attachment_id, '_wp_attachment_is_custom_header', $post_data['theme'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1698
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1699
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1700
	if ( ! $attachment = wp_prepare_attachment_for_js( $attachment_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1701
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1702
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1703
	echo json_encode( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1704
		'success' => true,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1705
		'data'    => $attachment,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1706
	) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1707
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1708
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1709
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1710
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1711
function wp_ajax_image_editor() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1712
	$attachment_id = intval($_POST['postid']);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1713
	if ( empty($attachment_id) || !current_user_can('edit_post', $attachment_id) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1714
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1715
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1716
	check_ajax_referer( "image_editor-$attachment_id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1717
	include_once( ABSPATH . 'wp-admin/includes/image-edit.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1718
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1719
	$msg = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1720
	switch ( $_POST['do'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1721
		case 'save' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1722
			$msg = wp_save_image($attachment_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1723
			$msg = json_encode($msg);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1724
			wp_die( $msg );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1725
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1726
		case 'scale' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1727
			$msg = wp_save_image($attachment_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1728
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1729
		case 'restore' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1730
			$msg = wp_restore_image($attachment_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1731
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1732
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1733
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1734
	wp_image_editor($attachment_id, $msg);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1735
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1736
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1737
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1738
function wp_ajax_set_post_thumbnail() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1739
	$json = ! empty( $_REQUEST['json'] ); // New-style request
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1740
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1741
	$post_ID = intval( $_POST['post_id'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1742
	if ( ! current_user_can( 'edit_post', $post_ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1743
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1744
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1745
	$thumbnail_id = intval( $_POST['thumbnail_id'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1746
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1747
	if ( $json )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1748
		check_ajax_referer( "update-post_$post_ID" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1749
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1750
		check_ajax_referer( "set_post_thumbnail-$post_ID" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1751
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1752
	if ( $thumbnail_id == '-1' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1753
		if ( delete_post_thumbnail( $post_ID ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1754
			$return = _wp_post_thumbnail_html( null, $post_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1755
			$json ? wp_send_json_success( $return ) : wp_die( $return );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1756
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1757
			wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1758
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1759
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1760
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1761
	if ( set_post_thumbnail( $post_ID, $thumbnail_id ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1762
		$return = _wp_post_thumbnail_html( $thumbnail_id, $post_ID );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1763
		$json ? wp_send_json_success( $return ) : wp_die( $return );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1764
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1765
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1766
	wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1767
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1768
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1769
function wp_ajax_date_format() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1770
	wp_die( date_i18n( sanitize_option( 'date_format', $_POST['date'] ) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1771
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1772
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1773
function wp_ajax_time_format() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1774
	wp_die( date_i18n( sanitize_option( 'time_format', $_POST['date'] ) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1775
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1776
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1777
function wp_ajax_wp_fullscreen_save_post() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1778
	$post_id = isset( $_POST['post_ID'] ) ? (int) $_POST['post_ID'] : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1779
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1780
	$post = $post_type = null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1781
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1782
	if ( $post_id )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1783
		$post = get_post( $post_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1784
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1785
	if ( $post )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1786
		$post_type = $post->post_type;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1787
	elseif ( isset( $_POST['post_type'] ) && post_type_exists( $_POST['post_type'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1788
		$post_type = $_POST['post_type'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1789
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1790
	check_ajax_referer('update-post_' . $post_id, '_wpnonce');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1791
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1792
	$post_id = edit_post();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1793
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1794
	if ( is_wp_error($post_id) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1795
		if ( $post_id->get_error_message() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1796
			$message = $post_id->get_error_message();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1797
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1798
			$message = __('Save failed');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1799
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1800
		echo json_encode( array( 'message' => $message, 'last_edited' => '' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1801
		wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1802
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1803
		$message = __('Saved.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1804
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1805
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1806
	if ( $post ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1807
		$last_date = mysql2date( get_option('date_format'), $post->post_modified );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1808
		$last_time = mysql2date( get_option('time_format'), $post->post_modified );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1809
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1810
		$last_date = date_i18n( get_option('date_format') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1811
		$last_time = date_i18n( get_option('time_format') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1812
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1813
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1814
	if ( $last_id = get_post_meta($post_id, '_edit_last', true) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1815
		$last_user = get_userdata($last_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1816
		$last_edited = sprintf( __('Last edited by %1$s on %2$s at %3$s'), esc_html( $last_user->display_name ), $last_date, $last_time );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1817
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1818
		$last_edited = sprintf( __('Last edited on %1$s at %2$s'), $last_date, $last_time );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1819
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1820
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1821
	echo json_encode( array( 'message' => $message, 'last_edited' => $last_edited ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1822
	wp_die();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1823
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1824
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1825
function wp_ajax_wp_remove_post_lock() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1826
	if ( empty( $_POST['post_ID'] ) || empty( $_POST['active_post_lock'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1827
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1828
	$post_id = (int) $_POST['post_ID'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1829
	if ( ! $post = get_post( $post_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1830
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1831
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1832
	check_ajax_referer( 'update-post_' . $post_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1833
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1834
	if ( ! current_user_can( 'edit_post', $post_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1835
		wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1836
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1837
	$active_lock = array_map( 'absint', explode( ':', $_POST['active_post_lock'] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1838
	if ( $active_lock[1] != get_current_user_id() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1839
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1840
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1841
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1842
	 * Filter the post lock window duration.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1843
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1844
	 * @since 3.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1845
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1846
	 * @param int $interval The interval in seconds the post lock duration should last, plus 5 seconds. Default 120.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1847
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1848
	$new_lock = ( time() - apply_filters( 'wp_check_post_lock_window', 120 ) + 5 ) . ':' . $active_lock[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1849
	update_post_meta( $post_id, '_edit_lock', $new_lock, implode( ':', $active_lock ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1850
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1851
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1852
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1853
function wp_ajax_dismiss_wp_pointer() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1854
	$pointer = $_POST['pointer'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1855
	if ( $pointer != sanitize_key( $pointer ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1856
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1857
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1858
//	check_ajax_referer( 'dismiss-pointer_' . $pointer );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1859
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1860
	$dismissed = array_filter( explode( ',', (string) get_user_meta( get_current_user_id(), 'dismissed_wp_pointers', true ) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1861
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1862
	if ( in_array( $pointer, $dismissed ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1863
		wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1864
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1865
	$dismissed[] = $pointer;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1866
	$dismissed = implode( ',', $dismissed );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1867
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1868
	update_user_meta( get_current_user_id(), 'dismissed_wp_pointers', $dismissed );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1869
	wp_die( 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1870
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1871
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1872
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1873
 * Get an attachment.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1874
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1875
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1876
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1877
function wp_ajax_get_attachment() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1878
	if ( ! isset( $_REQUEST['id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1879
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1880
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1881
	if ( ! $id = absint( $_REQUEST['id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1882
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1883
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1884
	if ( ! $post = get_post( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1885
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1886
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1887
	if ( 'attachment' != $post->post_type )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1888
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1889
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1890
	if ( ! current_user_can( 'upload_files' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1891
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1892
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1893
	if ( ! $attachment = wp_prepare_attachment_for_js( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1894
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1895
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1896
	wp_send_json_success( $attachment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1897
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1898
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1899
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1900
 * Query for attachments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1901
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1902
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1903
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1904
function wp_ajax_query_attachments() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1905
	if ( ! current_user_can( 'upload_files' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1906
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1907
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1908
	$query = isset( $_REQUEST['query'] ) ? (array) $_REQUEST['query'] : array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1909
	$query = array_intersect_key( $query, array_flip( array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1910
		's', 'order', 'orderby', 'posts_per_page', 'paged', 'post_mime_type',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1911
		'post_parent', 'post__in', 'post__not_in',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1912
	) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1913
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1914
	$query['post_type'] = 'attachment';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1915
	$query['post_status'] = 'inherit';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1916
	if ( current_user_can( get_post_type_object( 'attachment' )->cap->read_private_posts ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1917
		$query['post_status'] .= ',private';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1918
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1919
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1920
	 * Filter the arguments passed to WP_Query during an AJAX call for querying attachments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1921
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1922
	 * @since 3.7.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1923
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1924
	 * @param array $query An array of query variables. @see WP_Query::parse_query()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1925
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1926
	$query = apply_filters( 'ajax_query_attachments_args', $query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1927
	$query = new WP_Query( $query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1928
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1929
	$posts = array_map( 'wp_prepare_attachment_for_js', $query->posts );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1930
	$posts = array_filter( $posts );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1931
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1932
	wp_send_json_success( $posts );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1933
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1934
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1935
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1936
 * Save attachment attributes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1937
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1938
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1939
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1940
function wp_ajax_save_attachment() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1941
	if ( ! isset( $_REQUEST['id'] ) || ! isset( $_REQUEST['changes'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1942
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1943
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1944
	if ( ! $id = absint( $_REQUEST['id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1945
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1946
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1947
	check_ajax_referer( 'update-post_' . $id, 'nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1948
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1949
	if ( ! current_user_can( 'edit_post', $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1950
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1951
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1952
	$changes = $_REQUEST['changes'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1953
	$post    = get_post( $id, ARRAY_A );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1954
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1955
	if ( 'attachment' != $post['post_type'] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1956
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1957
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1958
	if ( isset( $changes['title'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1959
		$post['post_title'] = $changes['title'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1960
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1961
	if ( isset( $changes['caption'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1962
		$post['post_excerpt'] = $changes['caption'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1963
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1964
	if ( isset( $changes['description'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1965
		$post['post_content'] = $changes['description'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1966
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1967
	if ( isset( $changes['alt'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1968
		$alt = wp_unslash( $changes['alt'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1969
		if ( $alt != get_post_meta( $id, '_wp_attachment_image_alt', true ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1970
			$alt = wp_strip_all_tags( $alt, true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1971
			update_post_meta( $id, '_wp_attachment_image_alt', wp_slash( $alt ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1972
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1973
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1974
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1975
	wp_update_post( $post );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1976
	wp_send_json_success();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1977
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1978
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1979
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1980
 * Save backwards compatible attachment attributes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1981
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1982
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1983
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1984
function wp_ajax_save_attachment_compat() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1985
	if ( ! isset( $_REQUEST['id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1986
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1987
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1988
	if ( ! $id = absint( $_REQUEST['id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1989
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1990
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1991
	if ( empty( $_REQUEST['attachments'] ) || empty( $_REQUEST['attachments'][ $id ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1992
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1993
	$attachment_data = $_REQUEST['attachments'][ $id ];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1994
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1995
	check_ajax_referer( 'update-post_' . $id, 'nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1996
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1997
	if ( ! current_user_can( 'edit_post', $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1998
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1999
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2000
	$post = get_post( $id, ARRAY_A );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2001
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2002
	if ( 'attachment' != $post['post_type'] )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2003
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2004
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2005
	/** This filter is documented in wp-admin/includes/media.php */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2006
	$post = apply_filters( 'attachment_fields_to_save', $post, $attachment_data );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2007
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2008
	if ( isset( $post['errors'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2009
		$errors = $post['errors']; // @todo return me and display me!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2010
		unset( $post['errors'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2011
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2012
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2013
	wp_update_post( $post );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2014
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2015
	foreach ( get_attachment_taxonomies( $post ) as $taxonomy ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2016
		if ( isset( $attachment_data[ $taxonomy ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2017
			wp_set_object_terms( $id, array_map( 'trim', preg_split( '/,+/', $attachment_data[ $taxonomy ] ) ), $taxonomy, false );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2018
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2019
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2020
	if ( ! $attachment = wp_prepare_attachment_for_js( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2021
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2022
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2023
	wp_send_json_success( $attachment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2024
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2025
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2026
function wp_ajax_save_attachment_order() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2027
	if ( ! isset( $_REQUEST['post_id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2028
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2029
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2030
	if ( ! $post_id = absint( $_REQUEST['post_id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2031
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2032
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2033
	if ( empty( $_REQUEST['attachments'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2034
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2035
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2036
	check_ajax_referer( 'update-post_' . $post_id, 'nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2037
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2038
	$attachments = $_REQUEST['attachments'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2039
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2040
	if ( ! current_user_can( 'edit_post', $post_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2041
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2042
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2043
	$post = get_post( $post_id, ARRAY_A );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2044
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2045
	foreach ( $attachments as $attachment_id => $menu_order ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2046
		if ( ! current_user_can( 'edit_post', $attachment_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2047
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2048
		if ( ! $attachment = get_post( $attachment_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2049
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2050
		if ( 'attachment' != $attachment->post_type )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2051
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2052
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2053
		wp_update_post( array( 'ID' => $attachment_id, 'menu_order' => $menu_order ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2054
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2055
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2056
	wp_send_json_success();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2057
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2058
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2059
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2060
 * Generates the HTML to send an attachment to the editor.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2061
 * Backwards compatible with the media_send_to_editor filter and the chain
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2062
 * of filters that follow.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2063
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2064
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2065
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2066
function wp_ajax_send_attachment_to_editor() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2067
	check_ajax_referer( 'media-send-to-editor', 'nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2068
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2069
	$attachment = wp_unslash( $_POST['attachment'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2070
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2071
	$id = intval( $attachment['id'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2072
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2073
	if ( ! $post = get_post( $id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2074
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2075
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2076
	if ( 'attachment' != $post->post_type )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2077
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2078
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2079
	if ( current_user_can( 'edit_post', $id ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2080
		// If this attachment is unattached, attach it. Primarily a back compat thing.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2081
		if ( 0 == $post->post_parent && $insert_into_post_id = intval( $_POST['post_id'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2082
			wp_update_post( array( 'ID' => $id, 'post_parent' => $insert_into_post_id ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2083
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2084
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2085
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2086
	$rel = $url = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2087
	$html = $title = isset( $attachment['post_title'] ) ? $attachment['post_title'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2088
	if ( ! empty( $attachment['url'] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2089
		$url = $attachment['url'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2090
		if ( strpos( $url, 'attachment_id') || get_attachment_link( $id ) == $url )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2091
			$rel = ' rel="attachment wp-att-' . $id . '"';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2092
		$html = '<a href="' . esc_url( $url ) . '"' . $rel . '>' . $html . '</a>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2093
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2094
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2095
	remove_filter( 'media_send_to_editor', 'image_media_send_to_editor' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2096
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2097
	if ( 'image' === substr( $post->post_mime_type, 0, 5 ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2098
		$align = isset( $attachment['align'] ) ? $attachment['align'] : 'none';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2099
		$size = isset( $attachment['image-size'] ) ? $attachment['image-size'] : 'medium';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2100
		$alt = isset( $attachment['image_alt'] ) ? $attachment['image_alt'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2101
		$caption = isset( $attachment['post_excerpt'] ) ? $attachment['post_excerpt'] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2102
		$title = ''; // We no longer insert title tags into <img> tags, as they are redundant.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2103
		$html = get_image_send_to_editor( $id, $caption, $title, $align, $url, (bool) $rel, $size, $alt );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2104
	} elseif ( 'video' === substr( $post->post_mime_type, 0, 5 ) || 'audio' === substr( $post->post_mime_type, 0, 5 )  ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2105
		$html = stripslashes_deep( $_POST['html'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2106
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2107
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2108
	/** This filter is documented in wp-admin/includes/media.php */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2109
	$html = apply_filters( 'media_send_to_editor', $html, $id, $attachment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2110
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2111
	wp_send_json_success( $html );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2112
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2113
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2114
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2115
 * Generates the HTML to send a non-image embed link to the editor.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2116
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2117
 * Backwards compatible with the following filters:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2118
 * - file_send_to_editor_url
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2119
 * - audio_send_to_editor_url
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2120
 * - video_send_to_editor_url
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2121
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2122
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2123
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2124
function wp_ajax_send_link_to_editor() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2125
	check_ajax_referer( 'media-send-to-editor', 'nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2126
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2127
	if ( ! $src = wp_unslash( $_POST['src'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2128
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2129
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2130
	if ( ! strpos( $src, '://' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2131
		$src = 'http://' . $src;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2132
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2133
	if ( ! $src = esc_url_raw( $src ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2134
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2135
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2136
	if ( ! $title = trim( wp_unslash( $_POST['title'] ) ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2137
		$title = wp_basename( $src );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2138
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2139
	$html = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2140
	if ( $title )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2141
		$html = '<a href="' . esc_url( $src ) . '">' . $title . '</a>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2142
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2143
	// Figure out what filter to run:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2144
	$type = 'file';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2145
	if ( ( $ext = preg_replace( '/^.+?\.([^.]+)$/', '$1', $src ) ) && ( $ext_type = wp_ext2type( $ext ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2146
		&& ( 'audio' == $ext_type || 'video' == $ext_type ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2147
			$type = $ext_type;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2148
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2149
	/** This filter is documented in wp-admin/includes/media.php */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2150
	$html = apply_filters( $type . '_send_to_editor_url', $html, $src, $title );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2151
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2152
	wp_send_json_success( $html );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2153
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2154
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2155
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2156
 * Heartbeat API (experimental)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2157
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2158
 * Runs when the user is logged in.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2159
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2160
function wp_ajax_heartbeat() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2161
	if ( empty( $_POST['_nonce'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2162
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2163
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2164
	$response = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2165
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2166
	if ( false === wp_verify_nonce( $_POST['_nonce'], 'heartbeat-nonce' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2167
		// User is logged in but nonces have expired.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2168
		$response['nonces_expired'] = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2169
		wp_send_json($response);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2170
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2171
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2172
	// screen_id is the same as $current_screen->id and the JS global 'pagenow'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2173
	if ( ! empty($_POST['screen_id']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2174
		$screen_id = sanitize_key($_POST['screen_id']);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2175
	else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2176
		$screen_id = 'front';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2177
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2178
	if ( ! empty($_POST['data']) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2179
		$data = (array) $_POST['data'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2180
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2181
		/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2182
		 * Filter the Heartbeat response received.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2183
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2184
		 * @since 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2185
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2186
		 * @param array|object $response  The Heartbeat response object or array.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2187
		 * @param array        $data      The $_POST data sent.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2188
		 * @param string       $screen_id The screen id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2189
		 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2190
		$response = apply_filters( 'heartbeat_received', $response, $data, $screen_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2191
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2192
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2193
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2194
	 * Filter the Heartbeat response sent.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2195
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2196
	 * @since 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2197
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2198
	 * @param array|object $response  The Heartbeat response object or array.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2199
	 * @param string       $screen_id The screen id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2200
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2201
	$response = apply_filters( 'heartbeat_send', $response, $screen_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2202
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2203
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2204
	 * Fires when Heartbeat ticks in logged-in environments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2205
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2206
	 * Allows the transport to be easily replaced with long-polling.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2207
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2208
	 * @since 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2209
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2210
	 * @param array|object $response  The Heartbeat response object or array.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2211
	 * @param string       $screen_id The screen id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2212
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2213
	do_action( 'heartbeat_tick', $response, $screen_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2214
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2215
	// Send the current time according to the server
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2216
	$response['server_time'] = time();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2217
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2218
	wp_send_json($response);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2219
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2220
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2221
function wp_ajax_get_revision_diffs() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2222
	require ABSPATH . 'wp-admin/includes/revision.php';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2223
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2224
	if ( ! $post = get_post( (int) $_REQUEST['post_id'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2225
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2226
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2227
	if ( ! current_user_can( 'read_post', $post->ID ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2228
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2229
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2230
	// Really just pre-loading the cache here.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2231
	if ( ! $revisions = wp_get_post_revisions( $post->ID, array( 'check_enabled' => false ) ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2232
		wp_send_json_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2233
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2234
	$return = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2235
	@set_time_limit( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2236
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2237
	foreach ( $_REQUEST['compare'] as $compare_key ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2238
		list( $compare_from, $compare_to ) = explode( ':', $compare_key ); // from:to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2239
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2240
		$return[] = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2241
			'id' => $compare_key,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2242
			'fields' => wp_get_revision_ui_diff( $post, $compare_from, $compare_to ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2243
		);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2244
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2245
	wp_send_json_success( $return );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2246
}