Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tracking issue: Stabilizing network inspection in Node.js #53946

Open
1 of 5 tasks
cola119 opened this issue Jul 19, 2024 · 2 comments
Open
1 of 5 tasks

Tracking issue: Stabilizing network inspection in Node.js #53946

cola119 opened this issue Jul 19, 2024 · 2 comments
Labels
diagnostics_channel Issues and PRs related to diagnostics channel inspector Issues and PRs related to the V8 inspector protocol

Comments

@cola119
Copy link
Member

cola119 commented Jul 19, 2024

Related issue: nodejs/diagnostics#75
Initial implementation: #53593

This issue is for tracking the remaining work to make network inspection in Node.js stable and to provide a comprehensive debugging experience.

Network inspection features

  • ✅ - Implemented
  • 🚫 - No plan to implement at the moment
  • 🔍 - Need further investigation or discussion

Basic information

Feature http https http2 fetch WebSocket
type #54156 #54156 #56488
timestamp #53593 #53593 #56488
error #54246 #54246 #56488

Related protocols:

  • Network.requestWillBeSent
  • Network.responseReceived
  • Network.loadingFinished
  • Network.loadingFailed
  • Network.webSocketCreated
  • Network.webSocketClosed
  • Network.webSocketFrameError

Request details

The details of the request, such as the request body, cookies, and query parameters. The Network.Request object is used to represent the request. Some features such as referrerPolicy are only available in browser contexts.

Feature http https http2 fetch WebSocket
url #53593 #53593 #56488
method #53593 #53593 #56488
headers #54156 #54156 #56488
postData 🔍 🔍

Related protocols:

  • Network.requestWillBeSent
  • Network.websocketFrameSent
  • Network.webSocketWillSendHandshakeRequest

🔍 Response details

The details of the response, such as the response body, and headers. The Network.Response object is used to represent the response. Some features such as early hits are only available for browser contexts.

Feature http https http2 fetch WebSocket
url #54156 #54156 #56488
status #54156 #54156 #56488
headers #54156 #54156 #56488
mimeType

Caution

We can't consume the response body within the diagnostics_channel hook. We need to investigate how to handle the response body. (ref. #53593 (comment))

Related protocols:

  • Network.responseReceived
  • Network.websocketFrameReceived
  • Network.webSocketHandshakeResponseReceived

🔍 Request initiator

The initiator of the request, such as the script URL, the line number, and the stack trace. The Network.Initiator object is used to represent the initiator.

Feature http https http2 fetch WebSocket
initiator

Related protocols:

  • Network.requestWillBeSent
  • Network.webSocketCreated

🚫 Network conditions and throttling

The network conditions and throttling information of the request and response. The Network.emulateNetworkConditions command is used to emulate network conditions.

🚫 Security and authentication information

The security and authentication information of the request and response. The SecurityDetails object is used to represent the security details.

Others

If there are any other features that are not covered by the above categories, please let us know and we will add them to the list.

Node.js specific features

These are network inspection features specific to Node.js applications, including:

  • Monitoring incoming requests: Track and inspect incoming HTTP/HTTPS requests to the Node.js server, including headers, body, and timing information.
  • Monitoring outgoing responses: Track and inspect outgoing HTTP/HTTPS responses from the Node.js server, including headers, body, and timing information.

These features are not available in the browser context. We plan to support these features in collaboration with the ChromeDevTools team. To move forward with the implementation, we will create a design doc for these features and discuss the specs with the ChromeDevTools team.

Next steps

  • Implement the remaining features ready for implementation in the table above
  • Investigate the support for WebSocket inspection in Node.js
  • Investigate the support for fetch inspection in Node.js
  • Investigate the support for HTTP/2 inspection in Node.js
  • Document the design doc for Node.js specific features to collaborate with the ChromeDevTools team.
@cola119 cola119 added inspector Issues and PRs related to the V8 inspector protocol diagnostics_channel Issues and PRs related to diagnostics channel labels Jul 19, 2024
@cola119
Copy link
Member Author

cola119 commented Aug 5, 2024

Investigation of WebSocket support

Events

1. Network.webSocketCreated

Fired upon WebSocket creation.

Can this event be hooked? 🟢 (The undici:websocket:open diagnostics channel)

parameter description Can it be collected? Note
requestId Request identifier. 🟢
url WebSocket request URL. 🟢 Available in the undici:websocket:open diagnostics channel
initiator The name of the initiator.

2. Network.webSocketWillSendHandshakeRequest

Fired when WebSocket is about to initiate handshake.

Can this event be hooked? ❌ (No diagnostics channel)

parameter description Can it be collected? Note
requestId Request identifier. 🟢
timestamp Timestamp. 🟢
wallTime Timestamp. 🟢
request WebSocket request. See Network.WebSocketRequest

3. Network.webSocketHandshakeResponseReceived

Fired when WebSocket handshake response becomes available.

Can this event be hooked? ❌ (No diagnostics channel)

parameter description Can it be collected? Note
requestId Request identifier. 🟢
timestamp Timestamp. 🟢
response WebSocket response. See Network.WebSocketResponse

4. Network.webSocketFrameSent

Fired when WebSocket frame is sent.

Can this event be hooked? ❌ (No diagnostics channel)

parameter description Can it be collected? Note
requestId Request identifier 🟢
timestamp Timestamp 🟢
response WebSocket response See Network.WebSocketFrame

5. Network.webSocketFrameReceived

Fired when WebSocket frame is received.

Can this event be hooked? ❌ (No diagnostics channel)

parameter description Can it be collected? Note
requestId Request identifier. 🟢
timestamp Timestamp. 🟢
response WebSocket response. See Network.WebSocketFrame

6. Network.webSocketFrameError

Fired when WebSocket frame error occurs.

Can this event be hooked? ❌ (The undici:websocket:socket_error diagnostics channel is insufficient for collecting all necessary data)

parameter description Can it be collected? Note
requestId Request identifier. 🟢
timestamp Timestamp. 🟢
errorMessage Error message.

7. Network.webSocketClosed

Fired when WebSocket is closed.

Can this event be hooked? 🟢 (The undici:websocket:close diagnostics channel)

parameter description Can it be collected? Note
requestId Request identifier. 🟢
timestamp Timestamp. 🟢

Network.WebSocketRequest

Collectibility of the following data depends on the implementation of diagnostics channels.

parameter description Can it be collected? Note
headers HTTP request headers

Types

Network.WebSocketResponse

Collectibility of the following data depends on the implementation of diagnostics channels.

parameter description Can it be collected? Note
status HTTP response status.
statusText HTTP response status text.
headers HTTP response headers.
headersText HTTP response headers text.
requestHeaders HTTP request headers.
requestHeadersText HTTP request headers text.

Network.WebSocketFrame

Collectibility of the following data depends on the implementation of diagnostics channels.

parameter description Can it be collected? Note
opcode WebSocket opcode.
mask WebSocke mask.
payloadData WebSocket payload data.

@GrinZero

This comment was marked as spam.

nodejs-github-bot pushed a commit that referenced this issue Jan 5, 2025
The `Network.loadingFinished` should be deferred until the response is
complete and the data is fully consumed. Also, report correct request
url with the specified port by retrieving the host from the request
headers.

PR-URL: #56372
Refs: #53946
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Kohei Ueno <kohei.ueno119@gmail.com>
nodejs-github-bot pushed a commit that referenced this issue Jan 8, 2025
Add basic undici http tracking support via inspector protocol. This
allows tracking `fetch` calls with an inspector.

PR-URL: #56488
Refs: #53946
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Reviewed-By: Ethan Arrowood <ethan@arrowood.dev>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
targos pushed a commit that referenced this issue Jan 13, 2025
The `Network.loadingFinished` should be deferred until the response is
complete and the data is fully consumed. Also, report correct request
url with the specified port by retrieving the host from the request
headers.

PR-URL: #56372
Refs: #53946
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Kohei Ueno <kohei.ueno119@gmail.com>
targos pushed a commit that referenced this issue Jan 13, 2025
Add basic undici http tracking support via inspector protocol. This
allows tracking `fetch` calls with an inspector.

PR-URL: #56488
Refs: #53946
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Reviewed-By: Ethan Arrowood <ethan@arrowood.dev>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Ceres6 pushed a commit to Ceres6/node that referenced this issue Jan 13, 2025
The `Network.loadingFinished` should be deferred until the response is
complete and the data is fully consumed. Also, report correct request
url with the specified port by retrieving the host from the request
headers.

PR-URL: nodejs#56372
Refs: nodejs#53946
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Kohei Ueno <kohei.ueno119@gmail.com>
Ceres6 pushed a commit to Ceres6/node that referenced this issue Jan 13, 2025
Add basic undici http tracking support via inspector protocol. This
allows tracking `fetch` calls with an inspector.

PR-URL: nodejs#56488
Refs: nodejs#53946
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Reviewed-By: Ethan Arrowood <ethan@arrowood.dev>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
diagnostics_channel Issues and PRs related to diagnostics channel inspector Issues and PRs related to the V8 inspector protocol
Projects
None yet
Development

No branches or pull requests

2 participants