wp_get_shortlink() improvements.

* Return shortlinks for pages and public CPTs.
* Return shortlinks even when cruft-free links are not enabled.
* Unit tests

Props sillybean, layotte, cais
fixes #18632
see #14760


Built from https://develop.svn.wordpress.org/trunk@25030


git-svn-id: http://core.svn.wordpress.org/trunk@25017 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Ryan Boren 2013-08-15 20:09:09 +00:00
parent d203c9f6bb
commit 564d80e29f
2 changed files with 9 additions and 8 deletions

View File

@ -368,7 +368,7 @@ wp_nonce_field( 'closedpostboxes', 'closedpostboxesnonce', false );
<?php <?php
$sample_permalink_html = $post_type_object->public ? get_sample_permalink_html($post->ID) : ''; $sample_permalink_html = $post_type_object->public ? get_sample_permalink_html($post->ID) : '';
$shortlink = wp_get_shortlink($post->ID, 'post'); $shortlink = wp_get_shortlink($post->ID, 'post');
if ( !empty($shortlink) ) if ( !empty( $shortlink ) && $shortlink !== get_permalink( $post->ID ) )
$sample_permalink_html .= '<input id="shortlink" type="hidden" value="' . esc_attr($shortlink) . '" /><a href="#" class="button button-small" onclick="prompt(&#39;URL:&#39;, jQuery(\'#shortlink\').val()); return false;">' . __('Get Shortlink') . '</a>'; $sample_permalink_html .= '<input id="shortlink" type="hidden" value="' . esc_attr($shortlink) . '" /><a href="#" class="button button-small" onclick="prompt(&#39;URL:&#39;, jQuery(\'#shortlink\').val()); return false;">' . __('Get Shortlink') . '</a>';
if ( $post_type_object->public && ! ( 'pending' == get_post_status( $post ) && !current_user_can( $post_type_object->cap->publish_posts ) ) ) { if ( $post_type_object->public && ! ( 'pending' == get_post_status( $post ) && !current_user_can( $post_type_object->cap->publish_posts ) ) ) {

View File

@ -2351,20 +2351,21 @@ function wp_get_shortlink($id = 0, $context = 'post', $allow_slugs = true) {
global $wp_query; global $wp_query;
$post_id = 0; $post_id = 0;
if ( 'query' == $context && is_single() ) { if ( 'query' == $context && is_singular() ) {
$post_id = $wp_query->get_queried_object_id(); $post_id = $wp_query->get_queried_object_id();
$post = get_post( $post_id );
} elseif ( 'post' == $context ) { } elseif ( 'post' == $context ) {
$post = get_post($id); $post = get_post( $id );
$post_id = $post->ID; $post_id = $post->ID;
} }
$shortlink = ''; $shortlink = '';
// Return p= link for posts. // Return p= link for all public post types.
if ( !empty($post_id) && '' != get_option('permalink_structure') ) { if ( ! empty( $post_id ) ) {
$post = get_post($post_id); $post_type = get_post_type_object( $post->post_type );
if ( isset($post->post_type) && 'post' == $post->post_type ) if ( $post_type->public )
$shortlink = home_url('?p=' . $post->ID); $shortlink = home_url('?p=' . $post_id);
} }
return apply_filters('get_shortlink', $shortlink, $id, $context, $allow_slugs); return apply_filters('get_shortlink', $shortlink, $id, $context, $allow_slugs);