forked from subwaymatch/cdp-modify-response-example
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplaywright-example.js
103 lines (82 loc) · 3.57 KB
/
playwright-example.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
const { chromium } = require('playwright');
(async () => {
const browser = await chromium.launch({
headless: false,
});
const browserContext = await browser.newContext({
acceptDownloads: true,
});
const page = await browserContext.newPage();
// Create a new Chrome Devtools Protocol Session
const client = await browserContext.newCDPSession(page);
/*
Fetch.enable
https://chromedevtools.github.io/devtools-protocol/tot/Fetch/#method-enable
Enables issuing of requestPaused events. A request will be paused until client calls one of failRequest, fulfillRequest or continueRequest/continueWithAuth.
*/
await client.send('Fetch.enable', {
patterns: [
{
urlPattern: '*',
requestStage: 'Response',
},
],
});
/*
Fetch.requestPaused
https://chromedevtools.github.io/devtools-protocol/tot/Fetch/#event-requestPaused
Issued when the domain is enabled and the request URL matches the specified filter. The request is paused until the client responds with one of continueRequest, failRequest or fulfillRequest. The stage of the request can be determined by presence of responseErrorReason and responseStatusCode -- the request is at the response stage if either of these fields is present and in the request stage otherwise.
*/
await client.on('Fetch.requestPaused', async (reqEvent) => {
// Retrieve EventID
const { requestId } = reqEvent;
let responseHeaders = reqEvent.responseHeaders || [];
let contentType = '';
// Find and store 'content-type' header
for (let elements of responseHeaders) {
if (elements.name.toLowerCase() === 'content-type') {
contentType = elements.value;
}
}
if (contentType.endsWith('pdf') || contentType.endsWith('xml')) {
// Uncomment the line below to log response headers for debugging
// console.log(reqEvent.responseHeaders);
// Adding 'content-disposition: attachment' header will tell the browser to download the file instead of opening it in using built-in viewer
responseHeaders.push({
name: 'content-disposition',
value: 'attachment',
});
/*
Fetch.getResponseBody
https://chromedevtools.github.io/devtools-protocol/tot/Fetch/#method-getResponseBody
Causes the body of the response to be received from the server and returned as a single string. May only be issued for a request that is paused in the Response stage and is mutually exclusive with takeResponseBodyForInterceptionAsStream. Calling other methods that affect the request or disabling fetch domain before body is received results in an undefined behavior.
*/
const responseObj = await client.send('Fetch.getResponseBody', {
requestId,
});
/*
Fetch.fulfillRequest
https://chromedevtools.github.io/devtools-protocol/tot/Fetch/#method-fulfillRequest
Provides response to the request.
*/
await client.send('Fetch.fulfillRequest', {
requestId,
responseCode: 200,
responseHeaders,
body: responseObj.body,
});
} else {
// If the content-type is not what we're looking for, continue the request without modifying the response
await client.send('Fetch.continueRequest', { requestId });
}
});
await page.goto('https://pdf-xml-download-test.vercel.app/');
await page.waitForTimeout(100000);
/*
Fetch.disable
https://chromedevtools.github.io/devtools-protocol/tot/Fetch/#method-disable
Disables the fetch domain.
*/
await client.send('Fetch.disable');
await browser.close();
})();