happy-dom
Version:
Happy DOM is a JavaScript implementation of a web browser without its graphical user interface. It includes many web standards from WHATWG DOM and HTML.
73 lines (70 loc) • 2.53 kB
text/typescript
import FetchHTTPSCertificate from '../certificate/FetchHTTPSCertificate.js';
import { Buffer } from 'buffer';
/**
* Synchronous fetch script builder.
*/
export default class SyncFetchScriptBuilder {
/**
* Sends a synchronous request.
*
* @param request Request.
* @param request.url
* @param request.method
* @param request.headers
* @param request.body
* @returns Script.
*/
public static getScript(request: {
url: URL;
method: string;
headers: { [name: string]: string };
body?: Buffer | null;
}): string {
const sortedHeaders = {};
const headerNames = Object.keys(request.headers).sort();
for (const name of headerNames) {
sortedHeaders[name] = request.headers[name];
}
return `
const sendRequest = require('http${
request.url.protocol === 'https:' ? 's' : ''
}').request;
const options = ${JSON.stringify(
{
method: request.method,
headers: sortedHeaders,
agent: false,
rejectUnauthorized: true,
key: request.url.protocol === 'https:' ? FetchHTTPSCertificate.key : undefined,
cert: request.url.protocol === 'https:' ? FetchHTTPSCertificate.cert : undefined
},
null,
4
)};
const request = sendRequest('${request.url.href}', options, (incomingMessage) => {
let data = Buffer.alloc(0);
incomingMessage.on('data', (chunk) => {
data = Buffer.concat([data, Buffer.from(chunk)]);
});
incomingMessage.on('end', () => {
console.log(JSON.stringify({
error: null,
incomingMessage: {
statusCode: incomingMessage.statusCode,
statusMessage: incomingMessage.statusMessage,
rawHeaders: incomingMessage.rawHeaders,
data: data.toString('base64')
}
}));
});
incomingMessage.on('error', (error) => {
console.log(JSON.stringify({ error: error.message, incomingMessage: null }));
});
});
request.write(Buffer.from('${
request.body ? request.body.toString('base64') : ''
}', 'base64'));
request.end();
`;
}
}