- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 33.5k
http2: window size connection control #26962
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
Conversation
Allow to control the connection window size by setting local window size (local endpoints's window size) to the given window_size. To increase window size, this function may submit WINDOW_UPDATE frame to transmission queue. Pay attention, this function takes the absolute value of window size to set, rather than the delta, the delta is computed by the update operation.
| @nodejs/http2 PTAL | 
| | `0x0b` | Enhance Your Calm | `http2.constants.NGHTTP2_ENHANCE_YOUR_CALM` | | ||
| | `0x0c` | Inadequate Security | `http2.constants.NGHTTP2_INADEQUATE_SECURITY` | | ||
| | `0x0d` | HTTP/1.1 Required | `http2.constants.NGHTTP2_HTTP_1_1_REQUIRED` | | ||
| | `0x0d` | HTTP/1.1 Required | `http2.constants.NGHTTP2_HTTP_1_1_REQUIRED` | | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Duplicate line?
| than the delta. | ||
|  | ||
| ```js | ||
| clientSession.on('connect', (session) => sendSettings(session, (s) => cb(s))); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Perhaps (s) => cb(s) would be more clear, as documentation, if it were written with meaningful variable names (settings?). No need to squeeze it on 80ch; just go multi-line.
        
          
                doc/api/http2.md
              
                Outdated
          
        
      | --> | ||
|  | ||
| * `windowSize` {number} | ||
| * Returns: 0 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why return anything?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In fact it's not exaclty the case, at this stage it returns only zero or throws ERR_OUT_OF_RANGE, the function is mapped to nghttp2_session_set_local_window_size.
If the library changes its internal, the value will be returned.
If it does not fit the philosophy of node, we can return a generic errror that maps all errors at the native code level.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would you mind adding a unit test that verifies this behavior?
| the `Http2Session` after `msecs` milliseconds. The given `callback` is | ||
| registered as a listener on the `'timeout'` event. | ||
|  | ||
| #### http2session.setConnectionWindowSize(windowSize) | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would a getter and setter be better for an API?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's a good point, I am not sure to be able to detect it. There is not acknoledge on a SETTINGS_INITIAL_WINDOW_SIZE
But, we can add a test for testing the limit of the buffer allocation for instance and insure that code results are covered.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I will add the getter
| Ping @migounette , can you rebase and add some tests so that we can move forward ? | 
| Back on tracks for this activity, I will adresse it as soon as possible | 
| @migounette, this needs a rebase. | 
8ae28ff    to
    2935f72      
    Compare
  
    | Unfortunately this work appears to have stalled out. Closing but can reopen if it is picked back up again and rebased. | 
PR-URL: nodejs#35978 Fixes: nodejs#31084 Refs: nodejs#26962 Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Ricky Zhou <0x19951125@gmail.com>
Allow to control the connection window size by setting local window
size (local endpoints's window size) to the given window_size.
To increase window size, this function may submit WINDOW_UPDATE frame
to transmission queue.
Pay attention, this function takes the absolute value of window size to set,
rather than the delta, the delta is computed by the update operation.