wp-rocket icon indicating copy to clipboard operation
wp-rocket copied to clipboard

Console error caused by a conflict between Cloudflare’s Speed Brain and Preload Links feature.

Open johan-las opened this issue 2 months ago • 3 comments

Describe the bug Console error caused by a conflict between Cloudflare’s Speed Brain and Preload Links from WP Rocket.

Error displayed when hovering over a link:

GET https://dagmar.ro/produs/trapiche-oak-cask-cabernet-sauvignon-750ml/ net::ERR_ABORTED 503 (Service Unavailable)

The error is on this line:

document.head.appendChild(n)

Related to a JavaScript as data:text/javascript;base64,...

The decoded script is :

(function() {
"use strict";var r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e=function(){function i(e,t){for(var n=0;n<t.length;n++){var i=t[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,i.key,i)}}return function(e,t,n){return t&&i(e.prototype,t),n&&i(e,n),e}}();function i(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var t=function(){function n(e,t){i(this,n),this.browser=e,this.config=t,this.options=this.browser.options,this.prefetched=new Set,this.eventTime=null,this.threshold=1111,this.numOnHover=0}return e(n,[{key:"init",value:function(){!this.browser.supportsLinkPrefetch()||this.browser.isDataSaverModeOn()||this.browser.isSlowConnection()||(this.regex={excludeUris:RegExp(this.config.excludeUris,"i"),images:RegExp(".("+this.config.imageExt+")$","i"),fileExt:RegExp(".("+this.config.fileExt+")$","i")},this._initListeners(this))}},{key:"_initListeners",value:function(e){-1<this.config.onHoverDelay&&document.addEventListener("mouseover",e.listener.bind(e),e.listenerOptions),document.addEventListener("mousedown",e.listener.bind(e),e.listenerOptions),document.addEventListener("touchstart",e.listener.bind(e),e.listenerOptions)}},{key:"listener",value:function(e){var t=e.target.closest("a"),n=this._prepareUrl(t);if(null!==n)switch(e.type){case"mousedown":case"touchstart":this._addPrefetchLink(n);break;case"mouseover":this._earlyPrefetch(t,n,"mouseout")}}},{key:"_earlyPrefetch",value:function(t,e,n){var i=this,r=setTimeout(function(){if(r=null,0===i.numOnHover)setTimeout(function(){return i.numOnHover=0},1e3);else if(i.numOnHover>i.config.rateThrottle)return;i.numOnHover++,i._addPrefetchLink(e)},this.config.onHoverDelay);t.addEventListener(n,function e(){t.removeEventListener(n,e,{passive:!0}),null!==r&&(clearTimeout(r),r=null)},{passive:!0})}},{key:"_addPrefetchLink",value:function(i){return this.prefetched.add(i.href),new Promise(function(e,t){var n=document.createElement("link");n.rel="prefetch",n.href=i.href,n.onload=e,n.onerror=t,document.head.appendChild(n)}).catch(function(){})}},{key:"_prepareUrl",value:function(e){if(null===e||"object"!==(void 0===e?"undefined":r(e))||!1 in e||-1===["http:","https:"].indexOf(e.protocol))return null;var t=e.href.substring(0,this.config.siteUrl.length),n=this._getPathname(e.href,t),i={original:e.href,protocol:e.protocol,origin:t,pathname:n,href:t+n};return this._isLinkOk(i)?i:null}},{key:"_getPathname",value:function(e,t){var n=t?e.substring(this.config.siteUrl.length):e;return n.startsWith("/")||(n="/"+n),this._shouldAddTrailingSlash(n)?n+"/":n}},{key:"_shouldAddTrailingSlash",value:function(e){return this.config.usesTrailingSlash&&!e.endsWith("/")&&!this.regex.fileExt.test(e)}},{key:"_isLinkOk",value:function(e){return null!==e&&"object"===(void 0===e?"undefined":r(e))&&(!this.prefetched.has(e.href)&&e.origin===this.config.siteUrl&&-1===e.href.indexOf("?")&&-1===e.href.indexOf("#")&&!this.regex.excludeUris.test(e.href)&&!this.regex.images.test(e.href))}}],[{key:"run",value:function(){"undefined"!=typeof RocketPreloadLinksConfig&&new n(new RocketBrowserCompatibilityChecker({capture:!0,passive:!0}),RocketPreloadLinksConfig).init()}}]),n}();t.run();
}());

From the customer:

  • yes, if I disable Preload and Links Preload in wp rocket, with Speed Brain enabled, no error appears.
  • if I disable only Links Preload with Speed ​​Brain enabled, the errors appear.
  • if I keep preload and links preload active in wp rocket and disable Speed ​​Brain in cloudflare, no error appears.

If I remove the content of rocket-preload-links-js-after with Speed Brain enable, I don’t see the console error.

To Reproduce Steps to reproduce the behavior:

  1. Go to the customer website when Speed Brain is enabled
  2. Open the browser console
  3. Mouse over any links
  4. See the console error

Expected behavior No conflict should happen.

Screenshots

Image Image

Desktop (please complete the following information):

  • Browser Chrome, Firefox
  • Version Latest

Additional context Slack: https://group-onecom.slack.com/archives/C08F4M3BBJL/p1760611756031269 Ticket: https://secure.helpscout.net/conversation/3105566681#thread-9476388598

johan-las avatar Oct 16 '25 13:10 johan-las

Related: https://secure.helpscout.net/conversation/3138472993/599807

viobru avatar Nov 13 '25 17:11 viobru

Related: https://secure.helpscout.net/conversation/3138527469/599828

WordPresseur avatar Nov 14 '25 07:11 WordPresseur