Skip to content

Commit

Permalink
[7.x] [Reporting] Fix map tiles not loading by using Chrome's Remote …
Browse files Browse the repository at this point in the history
…Protocol (#55137) (#55235)

* [Reporting] Fix map tiles not loading by using Chrome's Remote Protocol (#55137)

* WIP Fixing map tiles and such

* Small comment and importing map from dolash

* Better destructuring and comments

Co-authored-by: Elastic Machine <elasticmachine@users.noreply.github.com>

* Fixing type woes in reportin'

* Fixing dupe export

Co-authored-by: Elastic Machine <elasticmachine@users.noreply.github.com>
  • Loading branch information
Joel Griffith and elasticmachine authored Jan 18, 2020
1 parent 9d70773 commit 9e8b3ea
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
* you may not use this file except in compliance with the Elastic License.
*/

import { trunc } from 'lodash';
import { trunc, map } from 'lodash';
import open from 'opn';
import { parse as parseUrl } from 'url';
import { Page, SerializableOrJSHandle, EvaluateFn } from 'puppeteer';
Expand All @@ -15,6 +15,7 @@ import {
ConditionalHeaders,
ConditionalHeadersConditions,
ElementPosition,
InterceptedRequest,
NetworkPolicy,
} from '../../../../types';

Expand Down Expand Up @@ -59,35 +60,57 @@ export class HeadlessChromiumDriver {
}: { conditionalHeaders: ConditionalHeaders; waitForSelector: string },
logger: LevelLogger
) {
await this.page.setRequestInterception(true);
logger.info(`opening url ${url}`);
// @ts-ignore
const client = this.page._client;
let interceptedCount = 0;

this.page.on('request', interceptedRequest => {
const interceptedUrl = interceptedRequest.url();
await this.page.setRequestInterception(true);

// We have to reach into the Chrome Devtools Protocol to apply headers as using
// puppeteer's API will cause map tile requests to hang indefinitely:
// https://github.com/puppeteer/puppeteer/issues/5003
// Docs on this client/protocol can be found here:
// https://chromedevtools.github.io/devtools-protocol/tot/Fetch
client.on('Fetch.requestPaused', (interceptedRequest: InterceptedRequest) => {
const {
requestId,
request: { url: interceptedUrl },
} = interceptedRequest;
const allowed = !interceptedUrl.startsWith('file://');
const isData = interceptedUrl.startsWith('data:');

// We should never ever let file protocol requests go through
if (!allowed || !this.allowRequest(interceptedUrl)) {
logger.error(`Got bad URL: "${interceptedUrl}", closing browser.`);
interceptedRequest.abort('blockedbyclient');
client.send('Fetch.failRequest', {
errorReason: 'Aborted',
requestId,
});
this.page.browser().close();
throw new Error(`Received disallowed outgoing URL: "${interceptedUrl}", exiting`);
}

if (this._shouldUseCustomHeaders(conditionalHeaders.conditions, interceptedUrl)) {
logger.debug(`Using custom headers for ${interceptedUrl}`);
interceptedRequest.continue({
headers: {
...interceptedRequest.headers(),
const headers = map(
{
...interceptedRequest.request.headers,
...conditionalHeaders.headers,
},
(value, name) => ({
name,
value,
})
);
client.send('Fetch.continueRequest', {
requestId,
headers,
});
} else {
const loggedUrl = isData ? this.truncateUrl(interceptedUrl) : interceptedUrl;
logger.debug(`No custom headers for ${loggedUrl}`);
interceptedRequest.continue();
client.send('Fetch.continueRequest', { requestId });
}
interceptedCount = interceptedCount + (isData ? 0 : 1);
});
Expand Down
15 changes: 15 additions & 0 deletions x-pack/legacy/plugins/reporting/types.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -340,3 +340,18 @@ export interface AbsoluteURLFactoryOptions {
hostname: string;
port: string | number;
}

export interface InterceptedRequest {
requestId: string;
request: {
url: string;
method: string;
headers: {
[key: string]: string;
};
initialPriority: string;
referrerPolicy: string;
};
frameId: string;
resourceType: string;
}

0 comments on commit 9e8b3ea

Please sign in to comment.