Make WordPress Core

Opened 14 years ago

Closed 11 years ago

Last modified 11 years ago

#15256 closed defect (bug) (fixed)

?cat=## permalinks do not redirect when category is a parent

Reported by: froman118's profile froman118 Owned by: wonderboymusic's profile wonderboymusic
Milestone: 3.8 Priority: high
Severity: normal Version: 3.0.1
Component: Canonical Keywords: has-patch needs-testing needs-unit-tests early
Focuses: Cc:

Description

One of my plugin users reported this while using dropdowns to display his categories: http://wordpress.org/support/topic/plugin-my-category-order-multiple-widget-support-broken

I was able to duplicate it on my own site in 3.0.1. Any category that has children displayed in the dropdown will redirect to /?cat=## instead of the the friendly /category-name permalink when selected. Select any other category or one of the children and they redirect correctly.

Any thoughts?

Attachments (3)

15256.patch (737 bytes) - added by SergeyBiryukov 13 years ago.
15256.diff (834 bytes) - added by dd32 13 years ago.
15256.2.diff (1.9 KB) - added by dd32 13 years ago.

Download all attachments as: .zip

Change History (24)

#1 @froman118
14 years ago

Just tested again and saw that it happens even if the child categories aren't displayed in dropdown.

#2 @dd32
14 years ago

  • Milestone Awaiting Review deleted
  • Resolution set to wontfix
  • Status changed from new to closed

The dropdown list is doing exactly what it's designed to do. Give a cat input with the category ID.

In this case, Canonical should redirect it to the permalink, If that's not happening, please test on the latest wordpress 3.1 RC and re-open with feedback.

#3 @nacin
14 years ago

It indeed works.

#4 @nacin
13 years ago

  • Keywords changed from template, redirect, category to template redirect, category
  • Resolution wontfix deleted
  • Status changed from closed to reopened

As andrewspittle pointed out to me, cat=X doesn't redirect, there's no canonical there, only on category_name.

#5 follow-up: @dd32
13 years ago

  • Component changed from Permalinks to Canonical
  • Keywords changed from template redirect, category to template redirect category
  • Milestone set to Future Release
  • Summary changed from wp_dropdown_categories() redirects parent categories to /?cat=## to ?cat=## permalinks do not redirect when category is a parent

As andrewspittle pointed out to me, cat=X doesn't redirect, there's no canonical there, only on category_name.

Alright, So I've duplicated it. ?cat=123 redirects, as long as it's a child category or is a top level category with no children. ?cat=456 doesn't redirect if it has childen, this is because the canonical code doesn't redirect on multiple category queries (which a parent category query is)

A quick hack "hack" would be to restore a block like this before the current taxonomy redirection code:

		} elseif ( is_category() && !empty($_GET['cat']) ) {
			if ( $redirect_url = get_term_link( (int)$_GET['cat'], 'category') )
				$redirect['query'] = remove_query_arg('cat', $redirect['query']);

however, that has the downside that it'll probably break on other taxonomy queries, or multi-query_var queries, which is what the current code was designed to fix.

#6 @dd32
13 years ago

  • Keywords needs-patch added; template redirect category removed
  • Milestone changed from Future Release to 3.3
  • Priority changed from normal to high

Just pushing this into 3.3 and raising the priority, This should've never occurred, and needs to be fixed.

#7 @minaguib
13 years ago

Hi folks

Ran into this on the latest release (version 3.2.1)

The bug is actually not just cosmetic, and in my case it causes serious breakage.

The breakage occurs if, like in my case, posts have a custom permalink structure. In my case I use "/places/%postname%"

When that's the case, and there are more than N posts in the category index requiring pagination, the breakage is as follows:

  1. User chooses one of the affected categories, goes to URL /?cat=5 and does not get redirected to slug
  2. User scrolls past N entries, uses pagination to click on page 2
  3. User goes to URL: /page/2?cat=5
  4. Which is a broken/invalid URL. Instead of seeing the listing for page 2, they see the homepage

It'd be great if this can be fixed in the next release. All my current options suck (disabling pagination / making the entries-per-page a large number / removing child categories / disabling pretty permalinks and using the default /?p=X ).

#8 in reply to: ↑ 5 @SergeyBiryukov
13 years ago

  • Keywords has-patch needs-testing added; needs-patch removed

Replying to dd32:

A quick hack "hack" would be to restore a block like this before the current taxonomy redirection code:

		} elseif ( is_category() && !empty($_GET['cat']) ) {
			if ( $redirect_url = get_term_link( (int)$_GET['cat'], 'category') )
				$redirect['query'] = remove_query_arg('cat', $redirect['query']);

however, that has the downside that it'll probably break on other taxonomy queries, or multi-query_var queries, which is what the current code was designed to fix.

15256.patch restores this block along with the condition from [10396], to prevent redirect on ?cat=1,2. Doesn't seem to break anything so far, but needs more testing.

Or is there a better way to fix this?

Replying to minaguib:

  1. User goes to URL: /page/2?cat=5
  2. Which is a broken/invalid URL. Instead of seeing the listing for page 2, they see the homepage

Can't reproduce this. URL like that still shows page 2 of category 5. Didn't check 3.2.1 though, only 3.3-trunk.

@dd32
13 years ago

#9 follow-up: @dd32
13 years ago

Or is there a better way to fix this?

I've been thinking about it a bit, and in testing, it's hit me that only categories (not custom taxonomies, etc) include children in the Tax Query array, which is where the issue is originating from.

Upon looking into WP_Tax_Query I've found that children are, by default, included - rendering query.php loading them being redundant. The attached patch removes category children from the array, allowing WP_Tax_Query to fall back to it's default of loading the children itself. Logically, this results in no logic change to the Query process, but does however, fix the Canonicalism process (as now WP_Query now states that a single category was requested - which is true)).

However, 15256.patch is also viable. I'd like someone elses opinion on it before going ahead with either though.

#10 @nacin
13 years ago

15256.diff seems to make much more sense as it corrects the root problem rather than a symptom.

#11 in reply to: ↑ 9 @SergeyBiryukov
13 years ago

Replying to dd32:

The attached patch removes category children from the array, allowing WP_Tax_Query to fall back to it's default of loading the children itself.

That would result in #16152 again.

#12 @dd32
13 years ago

That would result in #16152 again.

Hmm Good catch.. I hadn't blamed it right. Ultimately, cat != category__in

@dd32
13 years ago

#13 @dd32
13 years ago

attachment 15256.2.diff added

Yet another shot at the root cause. Took the line of parsing 'cat' to it's own tax query rather than piggybacking on category__in. Doesn't appear to regress anything that I can see, If a query is using both 'cat' and 'category__in' that'll result in 2 queries in WP_Tax_Query (unless it rolls same/similar queries into one)

#14 @dd32
13 years ago

  • Keywords needs-unit-tests added

#15 @markjaquith
13 years ago

  • Keywords early added
  • Milestone changed from 3.3 to Future Release

This needs to be fixed early in a cycle.

#16 @petervanderdoes
12 years ago

  • Cc peter@… added

As of WordPress 3.5.1 this is still an issue.

Any plans on fixing this?

#17 @SergeyBiryukov
12 years ago

#23604 was marked as a duplicate.

#18 @orion42
11 years ago

  • Cc orion42 added

I've got the same problem with the 3.6 wp version. I also have a custom permalink structure.
If I have a parent-category 1 and a child-category 2 I have:

mysite.com/?cat=1 => no redirect

mysite.com/?cat=2 => redirect to mysite.com/category/child-category

I discover this behavior due to the category-list widget and my webpage stat.
I've tried to use last .diff but doesn't work for me.

Last edited 11 years ago by orion42 (previous) (diff)

#19 @orion42
11 years ago

The first patch (15256.patch on wp-includes/canonical.php) is working form me. Just a small fix, in wp 3.6 this file has 12 more rows, so the patch should be included at row 160-162 instead of 148-150.

Version 0, edited 11 years ago by orion42 (next)

#20 @wonderboymusic
11 years ago

  • Owner set to wonderboymusic
  • Resolution set to fixed
  • Status changed from reopened to closed

In 26090:

Fix canonical redirection of cat as described in #15256 by rolling the cat query var into tax_query, instead of category__in / category__not_in. Top-level categories were only redirecting properly if they had no children.

All unit tests pass. Tests marked for #15256 are no longer skipped.

Fixes #15256.
Props dd32.

#21 @SergeyBiryukov
11 years ago

  • Milestone changed from Future Release to 3.8
Note: See TracTickets for help on using tickets.