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

Create plugin support for CDN'ing of static assets. #10102

Merged
merged 50 commits into from
Sep 19, 2018

Conversation

georgestephanis
Copy link
Member

@georgestephanis georgestephanis commented Sep 5, 2018

Add in CDN hosted versions of Core / Jetpack scripts and styles to speed up sites and better cross-site cacheability.

To do:

  • Add caching to external http calls so they're not requested on each load.
  • Abstract out plugin script/style swapping to enable for other plugins (like WooCommerce) as well.
  • Confirm RTL styles are handled correctly.

Testing instructions:

  • Activate Photon CDN through the old module settings. Confirm that scripts / styles are now pointing to c0.wp.com resources in the page source. If testing using a development version, you can use a filter to override versions to production versions:
add_filter( 'jetpack_cdn_plugin_slug_and_version', function( $values ) {
	return array( 'jetpack', '6.5' );
} );
add_filter( 'jetpack_cdn_core_version_and_locale', function( $values ) {
	return array( '4.9.7', 'en_US' );
} );
  • Make sure everything loads in a couple browsers.
  • Test in multisite
  • Test in subfolder installs.
  • Test in RTL

Proposed changelog entry for your changes:

  • Speed up sites and increase max concurrent connections through Photon by cloud-hosting Jetpack and WordPress Core scripts, styles, and assets in addition to content images.

@georgestephanis georgestephanis added [Type] Enhancement Changes to an existing feature — removing, adding, or changing parts of it [Feature] Photon aka "Image CDN". Feature developed in the Image CDN package and shipped in multiple plugins [Type] Feature Request labels Sep 5, 2018
@georgestephanis georgestephanis self-assigned this Sep 5, 2018
@georgestephanis georgestephanis requested a review from a team as a code owner September 5, 2018 21:26
@jetpackbot
Copy link

jetpackbot commented Sep 5, 2018

That's a great PR description, thank you so much for your effort!

Generated by 🚫 dangerJS

We shouldn't need versino numbers as the core version is in the path.
Make it easier to do WooCommerce and others as well.
@georgestephanis
Copy link
Member Author

I'm unsure if it may be wiser to change how we swap the urls and such to a just in time based off a later filter or action.

@georgestephanis
Copy link
Member Author

I'm probably okay skipping exceptions for the emoji ones for the moment -- I don't want the initial PR to be too epically complex.

Good catch on Akismet -- I think that's because it's coming back with the core hashes, as it's bundled in the zip -- but not getting pulled over by @bazza's cdn. Not a big deal, I'll just prune them from what gets rewritten.

Talking to @claudiulodro about WooCommerce in Slack currently, seeing when we can get WC core onboard. They're currently past feature freeze, so it'll need to probably be for 3.6

This will break the CDN'ing of scripts, and as they're being served over HTTP/2 concatenation provides less benefit over the ability of the browser to cache individual assets.
jeherve added a commit that referenced this pull request Sep 18, 2018
Up until now, no rtl files or min files were generated when running `yarn build`.
This caused issues on RTL sites, but also in other places where we look for the file,
like in the work we are doing in #10102
Instead of hitting the API and related overhead, let's just assume that if Core is a publicly released version (no `-dev` or `-rc2` versions or the like) that the tag will be in the CDN, and then rewrite any css/js files in the `wp-includes` and `wp-admin` directories.
@zinigor
Copy link
Member

zinigor commented Sep 18, 2018

@georgestephanis sorry, there seems to be a problem with your latest change. It looks like Jetpack, and maybe some other plugins as well, enqueue assets with URLs like this:
umz2zkxmqy-3000x3000

We're going to be breaking these for all plugins that rely on that mechanism. We could probably blacklist URLs that have admin-ajax in them, but that sounds risky because other plugins might do something similar with a different URL. What's your opinion on this?

@georgestephanis
Copy link
Member Author

Ahhh shucks. Okay. Good find, I'll add a check.

@matticbot
Copy link
Contributor

Caution: This PR has changes that must be merged to WordPress.com
Please review this diff before merging: D18161-code. (updated diff)

@georgestephanis
Copy link
Member Author

That should have it fixed, @zinigor

@zinigor
Copy link
Member

zinigor commented Sep 19, 2018

Tested, fixes the problem, thank you! And huge props for @dereksmart for finding the problem!

@jeherve
Copy link
Member

jeherve commented Sep 19, 2018

I tested the PR one more time, and did not run into any major issues. It works well.

One quick note is that you can't really test this when using the Lazy Images feature; since we've modified Lazy Images in the past few weeks, the .js file served from the CDN is not compatible with the current development version of Jetpack.

@georgestephanis
Copy link
Member Author

Once it's launchable, I'd like to switch it to only cdn on public versions of the codebase. Should remedy that issue, but possibly make it harder to test.

Copy link
Member

@dereksmart dereksmart left a comment

Choose a reason for hiding this comment

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

🚀

Copy link
Member

@jeherve jeherve left a comment

Choose a reason for hiding this comment

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

Looking good! Let's test it for real now! 🚢

@georgestephanis georgestephanis merged commit e4c2786 into master Sep 19, 2018
@jeherve jeherve deleted the feature/assets-cdn branch September 19, 2018 20:18
jeherve pushed a commit that referenced this pull request Sep 19, 2018
* Add in support for `integrity` data for SRI.

* esc_attr ftw

* Add populating for integrity parameters based on .org api

plugin files only for now

* Correct the conditionals for the right error condition.

* Only swap out Jetpack asset urls if it's not a development version.

If it is a development version, we want to use local up to date assets.

* Tidy up the actions that it runs on

* Abstract some stuff like versions out

* Styles need love too

* Skip for already done items

* Add ability to pass in plugin and versino for getting checksums

* Add ability to get known plugin versions.

* Whitespace

* Move line

* Retool get core checksums to take args

* First pass at swapping out core files

* Oops.  Forgot to specify the proper item in the object.

* Add a better fallback and remove an instance that shouldn't happen.

* Some additional docs and tidying.

* Switch url pattern for cdn as per @bazza

* Ditch version numbers

We shouldn't need versino numbers as the core version is in the path.

* Abstract out the plugin resource swapping.

Make it easier to do WooCommerce and others as well.

* Purge SRI validation for the moment.

Wins from it are incremental, and we'll probably re-add it later -- but with better sourcing for the hashes.

* Somewhat big overhaul.

* Stop caring about hashes, just care about files.
* Add in caching of the file manifest based on plugin / core versions
* Strip down how much data we're stashing
* Use array_filter for more intelligible code than a foreach
* ???
* PROFIT!

* Fixed a fatal and a warning.

* Moved the CDN class to its own module to be able to turn it off and on.

* Simplify how we get the core checksums.

* Extract out the cdn domain to a class constant.

* Short circuit fn if no data returned.

* Don't loop through core files if there isn't a cdn'd version.

* Undo whitespace tweaks for less churn

* tabs > spaces

* Revert whitespace change for cleaner pr

* If querying for the current version of Jetpack, return the built manifest.

* Added override filters for plugin and core version strings.

* Added a line to generate the manifest as the latest stage before deploying to SVN.

* Add new method for testing if a version number is public and can be on t he cdn.

* Deactivate requiring a connection for now.

Helps with local testing, but we may need it on for shipping, just for TOS purposes.

* Fixed filter name, props @georgestephanis.

* Added the core asset version filter where it needed to be.

* Removed an unneeded excludes definition and fixed whitespace.

* Whitespace, comments and lint pass.

* Also swap to cdn versions on the admin side.

Props @jeherve for the catch.

* Only query the api if the version string looks like a public release.

* Let other plugins return their assets via a filter,

rather than an external api or stored option.

* Cache for up to 24h the lack of data about a specific plugin version.

* Add support for CDN'ing WooCommerce assets as well.

* Make sure wp-admin isn't concatenating scripts.

This will break the CDN'ing of scripts, and as they're being served over HTTP/2 concatenation provides less benefit over the ability of the browser to cache individual assets.

* Simplify the rewriting of Core assets.

Instead of hitting the API and related overhead, let's just assume that if Core is a publicly released version (no `-dev` or `-rc2` versions or the like) that the tag will be in the CDN, and then rewrite any css/js files in the `wp-includes` and `wp-admin` directories.

* Make sure we're not rewriting odd stuff like using admin-ajax to serve scripts
jeherve added a commit that referenced this pull request Sep 20, 2018
…10162)

Up until now, no rtl files or min files were generated when running `yarn build`.
This caused issues on RTL sites, but also in other places where we look for the file,
like in the work we are doing in #10102
@jeherve jeherve added [Status] Has Changelog and removed [Status] Needs Changelog [Status] Needs Review To request a review from fellow Jetpack developers. Label will be renamed soon. labels Sep 21, 2018
@jeherve jeherve added [Feature] Asset CDN and removed [Feature] Photon aka "Image CDN". Feature developed in the Image CDN package and shipped in multiple plugins labels Oct 5, 2018
jeherve pushed a commit that referenced this pull request Dec 18, 2018
When the static asset CDN of Jetpack is loaded, the translations for Gutenberg don'tt load properly because the filename is generated for a wrong path.

Also fixes Automattic/wp-calypso#29309

This has been extensively discussed in https://core.trac.wordpress.org/ticket/45528

#### Changes proposed in this Pull Request:

* This implements the filter that has been introduced into Core.

#### Testing instructions:

Prequisit: WordPress 5.0.2(alpha) or trunk

1. Set your WordPress to another language than English.
2. Activate Jetpack Static Asset CDN.
3. Potentially add a filter to your WordPress if it's running trunk (see #10102)
4. Create a new post to open Gutenberg and observe broken translations.
5. Activate the patch: Translations should now load after a reload.

#### Proposed changelog entry for your changes:

* Fixes loading of the Block Editor UI translations when Static Asset CDN is used (requires WordPress 5.0.2)
@jeherve jeherve removed the [Status] Needs Testing We need to add this change to the testing call for this month's release label Apr 27, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Asset CDN [Focus] Performance [Type] Enhancement Changes to an existing feature — removing, adding, or changing parts of it [Type] Feature Request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants