Basically, you need a custom resource handler that returns the desired external URL Resource#getRequestPath()whenever a resource is requested primefaces:jquery/jquery.js.
eg.
public class CDNResourceHandler extends ResourceHandlerWrapper {
private ResourceHandler wrapped;
public CDNResourceHandler(ResourceHandler wrapped) {
this.wrapped = wrapped;
}
@Override
public Resource createResource(final String resourceName, final String libraryName) {
final Resource resource = super.createResource(resourceName, libraryName);
if (resource == null || !"primefaces".equals(libraryName) || !"jquery/jquery.js".equals(resourceName)) {
return resource;
}
return new ResourceWrapper() {
@Override
public String getRequestPath() {
return "http://mydomain.com/jquery/jquery.js";
}
@Override
public Resource getWrapped() {
return resource;
}
};
}
@Override
public ResourceHandler getWrapped() {
return wrapped;
}
}
, faces-config.xml :
<application>
<resource-handler>com.example.CDNResourceHandler</resource-handler>
</application>
JSF OmniFaces CDNResourceHandler,
<context-param>
<param-name>org.omnifaces.CDN_RESOURCE_HANDLER_URLS</param-name>
<param-value>primefaces:jquery/jquery.js=http://mydomain.com/jquery/jquery.js</param-value>
</context-param>