Opened 14 years ago
Closed 11 years ago
#14760 closed enhancement (fixed)
wp_get_shortlink not working on pages
Reported by: | mattsay | Owned by: | ryan |
---|---|---|---|
Milestone: | 3.7 | Priority: | normal |
Severity: | normal | Version: | 3.0 |
Component: | General | Keywords: | has-patch needs-testing dev-feedback |
Focuses: | Cc: |
Description
wp_get_shortlink doesn't return anything on pages.
reason:
2196 if ( isset($post->post_type) && 'post' == $post->post_type ) 2197 $shortlink = home_url('?p=' . $post->ID);
Attachments (8)
Change History (38)
#2
@
14 years ago
- Keywords needs-patch added
- Milestone changed from Awaiting Review to Future Release
- Type changed from feature request to enhancement
#4
@
13 years ago
- Version set to 3.0
Updated patch removes some cruft and makes sure shortlinks are generated only for public post types.
#5
follow-up:
↓ 13
@
13 years ago
- Cc lew@… added
Updated patch to remove the permalink_structure check. If the user does not have permalinks turned on, this function returns a blank string as the shortlink. It should be permalink agnostic... so plugins/themes can use it without worrying about permalink checks.
Thoughts?
#13
in reply to:
↑ 5
@
11 years ago
Replying to layotte:
Updated patch to remove the permalink_structure check. If the user does not have permalinks turned on, this function returns a blank string as the shortlink. It should be permalink agnostic... so plugins/themes can use it without worrying about permalink checks.
The reason why it returns a blank when the permalinks are off is because it isn't a valid shortlink — it's the same length as the existing link.
I see the argument that plugins/themes should be able to use it without checking the permalink structure (though really, if it returns nothing, then just call get_permalink() as a fallback — this already must occur since it was so limited to post type) — but the idea was to not show a "Get Shortlink" button if we weren't actually showing something shorter.
#14
@
11 years ago
Yeah, that's a pretty awful return value there. If the normal link is as short as it gets, then it should return the normal link. It's short too. Relying on plugins/themes to check for blank and call get_permalink is a bit silly.
I can see the use case for wanting to not show the button, however in that case then this function is badly named. The name "wp_get_shortlink" implies that it will return a shortlink. It doesn't imply that it will return something different based on external factors. If you want to check for that sort of thing, then that should be in something like "has_shortlink" or something.
#17
@
11 years ago
Otto beat me to it. Having the function return a blank is certainly not what most developers would expect. If there's no shorter link, it should just return the original link.
#18
in reply to:
↑ 16
@
11 years ago
Replying to ryan:
I'm leaning toward changing the behavior. Predictable is good.
I'm fine with that but the button should be hidden in those cases.
#19
@
11 years ago
Do you mean the "Get Shortlink" button on the Edit Post screen? In order to hide that when no shorter link is available, wouldn't we have to check for any shortlink-related plugins?
#20
@
11 years ago
A shortlink plugin would hook into this and presumably return a different shortlink, so that works either way.
#22
@
11 years ago
As a plugin could return nothing from that filter (which is a valid return value, and will still be used for non-public post types), the check should probably be $shortlink && $shortlink !== get_permalink( $post->ID )
.
#23
@
11 years ago
Updated the button patch. (I'm not integrating Ryan's because I'm having trouble checking out the unit tests.)
#26
follow-up:
↓ 27
@
11 years ago
Since the permalink for page IDs uses ?page_id= instead of ?p=, we'll need to add a case to the buttom patch.
#27
in reply to:
↑ 26
@
11 years ago
Replying to ryan:
Since the permalink for page IDs uses ?page_id= instead of ?p=, we'll need to add a case to the buttom patch.
Unless we think that qualifies as a shortlink. Technically, it is shorter, but meh.
#28
@
11 years ago
Actually, I don't think we need a case. If there's no permalink structure set, we fail the '' != get_option('permalink_structure')
test and wp_get_shortlink returns ?page_id=. The button doesn't show. If there is a permalink structure, the button shows. We get a ?p= shortlink instead of ?page_id=, but since it just redirects, I don't see that as a problem.
Doesn't work on custom post types either.