Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Media: Improve plugin compatibility of taxonomy query #13208

Merged
merged 5 commits into from
Jun 21, 2023

Conversation

chirag2208
Copy link
Contributor

@chirag2208 chirag2208 commented Apr 11, 2023

Context

We are using folders plugin to structure media files in folders, web stories plugin creates invalid SQL query which does not provide any results

Summary

When eb Stories plugin is active and there is no any $tax_query in WP_Query object it adds 0 = 1 in SQL query which is always wrong so not returning any results in WP_Query, Please check this video for more details: https://tinyurl.com/2anx49r9

Relevant Technical Choices

We have fixed issue in this file:
/wp-content/plugins/web-stories/includes/Media/Media_Source_Taxonomy.php added this code after line number: 382

if(empty($tax_query)) {
    return [
        [
            'taxonomy' => $this->taxonomy_slug,
            'field'    => 'slug',
            'terms'    => [
                self::TERM_POSTER_GENERATION,
                self::TERM_SOURCE_VIDEO,
                self::TERM_SOURCE_IMAGE,
                self::TERM_PAGE_TEMPLATE,
            ],
            'operator' => 'NOT IN',
        ],
    ];
}

To-do

Any filter functionality on WP media page

User-facing changes

Before: https://tinyurl.com/25j68dyu
After: https://tinyurl.com/23c7k7kd

Testing Instructions

Install Folders plugin from wordpress.org (https://wordpress.org/plugins/folders/)
After Installing folders on your wordpress website, go to media and create folders and assign some media items to that folders (check this video for how to create folders and assign media items to it) - https://tinyurl.com/2anx49r9 then click on any Folders it is not showing any results

This PR can be tested by following these steps:

  1. Create folders and assign some media items into it and then click on folders or follow the steps as shown in video (https://tinyurl.com/2anx49r9)

Reviews

Does this PR have a security-related impact?

No

Does this PR change what data or activity we track or use?

No

Does this PR have a legal-related impact?

No

Checklist

  • This PR addresses an existing issue and I have linked this PR to it in ZenHub
  • I have tested this code to the best of my abilities
  • I have verified accessibility to the best of my abilities (docs)
  • I have verified i18n and l10n (translation, right-to-left layout) to the best of my abilities
  • This code is covered by automated tests (unit, integration, and/or e2e) to verify it works as intended (docs)
  • I have added documentation where necessary
  • I have added a matching Type: XYZ label to the PR

@google-cla
Copy link

google-cla bot commented Apr 11, 2023

Thanks for your pull request! It looks like this may be your first contribution to a Google open source project. Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA).

View this failed invocation of the CLA check for more information.

For the most up to date status, view the checks section at the bottom of the pull request.

@swissspidy
Copy link
Collaborator

@chirag2208 Could you please sign the Contributor License Agreement (CLA) over at https://cla.developers.google.com/? We can't accept your contribution otherwise.

@chirag2208
Copy link
Contributor Author

I have signed CLA

@swissspidy
Copy link
Collaborator

Thanks a lot!

So I had a quick look and it indeed looks like the tax query nesting is not really correct. The array_unshift there doesn’t really do what the comment says it should.

It would be more accurate to do something like this:

/**
 * Merge with existing tax query if needed,
 * in a nested way so WordPress will run them
 * with an 'AND' relation. Example:
 *
 * [
 *   'relation' => 'AND', // implicit.
 *   [ this query ],
 *   [ [ any ], [ existing ], [ tax queries] ]
 * ]
 */
$new_tax_query = [
	'relation' => 'AND',
	[
		'taxonomy' => $this->taxonomy_slug,
		'field'    => 'slug',
		'terms'    => [
			self::TERM_POSTER_GENERATION,
			self::TERM_SOURCE_VIDEO,
			self::TERM_SOURCE_IMAGE,
			self::TERM_PAGE_TEMPLATE,
		],
		'operator' => 'NOT IN',
	],
];

if ( ! empty( $tax_query ) ) {
	$new_tax_query[] = [ $tax_query ];
}

return $new_tax_query;

Second, to make this work more accurately, we should increase the filter priorities so that it truly runs after all existing tax queries:

// Hide video posters from Media grid view.
add_filter( 'ajax_query_attachments_args', [ $this, 'filter_ajax_query_attachments_args' ], PHP_INT_MAX );
// Hide video posters from Media list view.
add_action( 'pre_get_posts', [ $this, 'filter_generated_media_attachments' ], PHP_INT_MAX );
// Hide video posters from web-stories/v1/media REST API requests.
add_filter( 'web_stories_rest_attachment_query', [ $this, 'filter_rest_generated_media_attachments' ], PHP_INT_MAX );

cc @ayushnirwal

@swissspidy swissspidy changed the title folders issue on media page Media: Improve plugin compatibility of taxonomy query Apr 28, 2023
@swissspidy swissspidy added Group: Media Group: WordPress Changes related to WordPress or Gutenberg integration labels Apr 28, 2023
@deshanki12
Copy link

Hi @swissspidy

This is great.

What is the next step now in order for this fix to go live?

@swissspidy
Copy link
Collaborator

This still needs testing and tests to verify this fixes bugs and doesn‘t cause regressions.

@swissspidy swissspidy added this to the 1.33.0 milestone May 2, 2023
@swissspidy swissspidy added P2 Should do soon Needs Tests labels May 10, 2023
Copy link
Collaborator

@AnuragVasanwala AnuragVasanwala left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@swissspidy LGTM ✅

Tested the PR in every possible way to make sure it doesn't have any conflicts.

@swissspidy swissspidy merged commit 636e2df into GoogleForCreators:main Jun 21, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Group: Media Group: WordPress Changes related to WordPress or Gutenberg integration Needs Tests P2 Should do soon
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants