feat(Network): introduce response.securityDetails() method (#1880)
This patch: - introduces `SecurityDetails` class that exposes a set of fields that describe properties of secure connection - introduces method `response.securityDetails()` that returns an instance of `SecurityDetails` object.
This commit is contained in:
parent
700244a29a
commit
856c431914
29
docs/api.md
29
docs/api.md
@ -215,9 +215,16 @@
|
|||||||
* [response.json()](#responsejson)
|
* [response.json()](#responsejson)
|
||||||
* [response.ok()](#responseok)
|
* [response.ok()](#responseok)
|
||||||
* [response.request()](#responserequest)
|
* [response.request()](#responserequest)
|
||||||
|
* [response.securityDetails()](#responsesecuritydetails)
|
||||||
* [response.status()](#responsestatus)
|
* [response.status()](#responsestatus)
|
||||||
* [response.text()](#responsetext)
|
* [response.text()](#responsetext)
|
||||||
* [response.url()](#responseurl)
|
* [response.url()](#responseurl)
|
||||||
|
- [class: SecurityDetails](#class-securitydetails)
|
||||||
|
* [securityDetails.issuer()](#securitydetailsissuer)
|
||||||
|
* [securityDetails.protocol()](#securitydetailsprotocol)
|
||||||
|
* [securityDetails.subjectName()](#securitydetailssubjectname)
|
||||||
|
* [securityDetails.validFrom()](#securitydetailsvalidfrom)
|
||||||
|
* [securityDetails.validTo()](#securitydetailsvalidto)
|
||||||
- [class: Target](#class-target)
|
- [class: Target](#class-target)
|
||||||
* [target.createCDPSession()](#targetcreatecdpsession)
|
* [target.createCDPSession()](#targetcreatecdpsession)
|
||||||
* [target.page()](#targetpage)
|
* [target.page()](#targetpage)
|
||||||
@ -2420,6 +2427,9 @@ Contains a boolean stating whether the response was successful (status in the ra
|
|||||||
#### response.request()
|
#### response.request()
|
||||||
- returns: <[Request]> A matching [Request] object.
|
- returns: <[Request]> A matching [Request] object.
|
||||||
|
|
||||||
|
#### response.securityDetails()
|
||||||
|
- returns: <[SecurityDetails]> An object with security details associated with the response. From the original object only the fields `subjectName`, `"issuer"`, `"validFrom"`, `"validTo"`, `"protocol"` are extracted.
|
||||||
|
|
||||||
#### response.status()
|
#### response.status()
|
||||||
- returns: <[number]>
|
- returns: <[number]>
|
||||||
|
|
||||||
@ -2433,6 +2443,25 @@ Contains the status code of the response (e.g., 200 for a success).
|
|||||||
|
|
||||||
Contains the URL of the response.
|
Contains the URL of the response.
|
||||||
|
|
||||||
|
### class: SecurityDetails
|
||||||
|
|
||||||
|
[SecurityDetails] class represents responses which are received by page.
|
||||||
|
|
||||||
|
#### securityDetails.issuer()
|
||||||
|
- returns: <[string]> A string with the name of issuer of the certificate.
|
||||||
|
|
||||||
|
#### securityDetails.protocol()
|
||||||
|
- returns: <[string]> String with the security protocol, eg. "TLS 1.2".
|
||||||
|
|
||||||
|
#### securityDetails.subjectName()
|
||||||
|
- returns: <[string]> Name of the subject to which the certificate was issued to.
|
||||||
|
|
||||||
|
#### securityDetails.validFrom()
|
||||||
|
- returns: <[number]> Timestamp stating the start of validity of the certificate.
|
||||||
|
|
||||||
|
#### securityDetails.validTo()
|
||||||
|
- returns: <[number]> Timestamp stating the end of validity of the certificate.
|
||||||
|
|
||||||
### class: Target
|
### class: Target
|
||||||
|
|
||||||
#### target.createCDPSession()
|
#### target.createCDPSession()
|
||||||
|
@ -253,7 +253,7 @@ class NetworkManager extends EventEmitter {
|
|||||||
if (!request)
|
if (!request)
|
||||||
return;
|
return;
|
||||||
const response = new Response(this._client, request, event.response.status, event.response.headers,
|
const response = new Response(this._client, request, event.response.status, event.response.headers,
|
||||||
event.response.fromDiskCache, event.response.fromServiceWorker);
|
event.response.fromDiskCache, event.response.fromServiceWorker, event.response.securityDetails);
|
||||||
request._response = response;
|
request._response = response;
|
||||||
this.emit(NetworkManager.Events.Response, response);
|
this.emit(NetworkManager.Events.Response, response);
|
||||||
}
|
}
|
||||||
@ -498,10 +498,11 @@ class Response {
|
|||||||
* @param {!Request} request
|
* @param {!Request} request
|
||||||
* @param {number} status
|
* @param {number} status
|
||||||
* @param {!Object} headers
|
* @param {!Object} headers
|
||||||
|
* @param {!Object} securityDetails
|
||||||
* @param {boolean} fromDiskCache
|
* @param {boolean} fromDiskCache
|
||||||
* @param {boolean} fromServiceWorker
|
* @param {boolean} fromServiceWorker
|
||||||
*/
|
*/
|
||||||
constructor(client, request, status, headers, fromDiskCache, fromServiceWorker) {
|
constructor(client, request, status, headers, fromDiskCache, fromServiceWorker, securityDetails = null) {
|
||||||
this._client = client;
|
this._client = client;
|
||||||
this._request = request;
|
this._request = request;
|
||||||
this._contentPromise = null;
|
this._contentPromise = null;
|
||||||
@ -513,6 +514,15 @@ class Response {
|
|||||||
this._headers = {};
|
this._headers = {};
|
||||||
for (const key of Object.keys(headers))
|
for (const key of Object.keys(headers))
|
||||||
this._headers[key.toLowerCase()] = headers[key];
|
this._headers[key.toLowerCase()] = headers[key];
|
||||||
|
this._securityDetails = {};
|
||||||
|
if (securityDetails) {
|
||||||
|
this._securityDetails = new SecurityDetails(
|
||||||
|
securityDetails['subjectName'],
|
||||||
|
securityDetails['issuer'],
|
||||||
|
securityDetails['validFrom'],
|
||||||
|
securityDetails['validTo'],
|
||||||
|
securityDetails['protocol']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -543,6 +553,13 @@ class Response {
|
|||||||
return this._headers;
|
return this._headers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {!SecurityDetails|Object}
|
||||||
|
*/
|
||||||
|
securityDetails() {
|
||||||
|
return this._securityDetails;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return {!Promise<!Buffer>}
|
* @return {!Promise<!Buffer>}
|
||||||
*/
|
*/
|
||||||
@ -631,6 +648,59 @@ function generateRequestHash(request) {
|
|||||||
return JSON.stringify(hash);
|
return JSON.stringify(hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class SecurityDetails {
|
||||||
|
/**
|
||||||
|
* @param {string} subjectName
|
||||||
|
* @param {string} issuer
|
||||||
|
* @param {number} validFrom
|
||||||
|
* @param {number} validTo
|
||||||
|
* @param {string} protocol
|
||||||
|
*/
|
||||||
|
|
||||||
|
constructor(subjectName, issuer, validFrom, validTo, protocol) {
|
||||||
|
this._subjectName = subjectName;
|
||||||
|
this._issuer = issuer;
|
||||||
|
this._validFrom = validFrom;
|
||||||
|
this._validTo = validTo;
|
||||||
|
this._protocol = protocol;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
subjectName() {
|
||||||
|
return this._subjectName;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
issuer() {
|
||||||
|
return this._issuer;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {number}
|
||||||
|
*/
|
||||||
|
validFrom() {
|
||||||
|
return this._validFrom;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {number}
|
||||||
|
*/
|
||||||
|
validTo() {
|
||||||
|
return this._validTo;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
protocol() {
|
||||||
|
return this._protocol;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
NetworkManager.Events = {
|
NetworkManager.Events = {
|
||||||
Request: 'request',
|
Request: 'request',
|
||||||
Response: 'response',
|
Response: 'response',
|
||||||
|
@ -150,6 +150,8 @@ describe('Puppeteer', function() {
|
|||||||
const response = await page.goto(httpsServer.EMPTY_PAGE).catch(e => error = e);
|
const response = await page.goto(httpsServer.EMPTY_PAGE).catch(e => error = e);
|
||||||
expect(error).toBe(null);
|
expect(error).toBe(null);
|
||||||
expect(response.ok()).toBe(true);
|
expect(response.ok()).toBe(true);
|
||||||
|
expect(response.securityDetails()).toBeTruthy();
|
||||||
|
expect(response.securityDetails().protocol()).toBe('TLS 1.2');
|
||||||
browser.close();
|
browser.close();
|
||||||
});
|
});
|
||||||
it('should reject all promises when browser is closed', async() => {
|
it('should reject all promises when browser is closed', async() => {
|
||||||
|
Loading…
Reference in New Issue
Block a user