2012-01-24 14:02:24 +01:00
|
|
|
/*
|
2013-07-12 17:19:03 +02:00
|
|
|
* nghttp2 - HTTP/2.0 C Library
|
2012-01-24 14:02:24 +01:00
|
|
|
*
|
|
|
|
* Copyright (c) 2012 Tatsuhiro Tsujikawa
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
* a copy of this software and associated documentation files (the
|
|
|
|
* "Software"), to deal in the Software without restriction, including
|
|
|
|
* without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
* permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
* the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be
|
|
|
|
* included in all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
|
|
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
|
|
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
|
|
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
#ifndef NGHTTP2_SESSION_H
|
|
|
|
#define NGHTTP2_SESSION_H
|
2012-01-24 14:02:24 +01:00
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif /* HAVE_CONFIG_H */
|
|
|
|
|
2013-07-12 17:19:03 +02:00
|
|
|
#include <nghttp2/nghttp2.h>
|
|
|
|
#include "nghttp2_pq.h"
|
|
|
|
#include "nghttp2_map.h"
|
|
|
|
#include "nghttp2_frame.h"
|
2013-07-19 17:08:14 +02:00
|
|
|
#include "nghttp2_hd.h"
|
2013-07-12 17:19:03 +02:00
|
|
|
#include "nghttp2_stream.h"
|
|
|
|
#include "nghttp2_buffer.h"
|
|
|
|
#include "nghttp2_outbound_item.h"
|
2014-01-26 07:44:43 +01:00
|
|
|
#include "nghttp2_int.h"
|
2012-03-26 16:35:20 +02:00
|
|
|
|
2012-05-08 15:59:34 +02:00
|
|
|
/*
|
|
|
|
* Option flags.
|
|
|
|
*/
|
|
|
|
typedef enum {
|
2013-08-08 18:23:39 +02:00
|
|
|
NGHTTP2_OPTMASK_NO_AUTO_STREAM_WINDOW_UPDATE = 1 << 0,
|
|
|
|
NGHTTP2_OPTMASK_NO_AUTO_CONNECTION_WINDOW_UPDATE = 1 << 1
|
2013-07-12 17:19:03 +02:00
|
|
|
} nghttp2_optmask;
|
2012-05-08 15:59:34 +02:00
|
|
|
|
2012-01-24 14:02:24 +01:00
|
|
|
typedef struct {
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_outbound_item *item;
|
2012-02-16 12:54:30 +01:00
|
|
|
/* Buffer for outbound frames. Used to pack one frame. The memory
|
|
|
|
pointed by framebuf is initially allocated by
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_session_{client,server}_new() and deallocated by
|
|
|
|
nghttp2_session_del() */
|
2012-01-24 14:02:24 +01:00
|
|
|
uint8_t *framebuf;
|
2012-02-16 12:54:30 +01:00
|
|
|
/* The capacity of framebuf in bytes */
|
|
|
|
size_t framebufmax;
|
|
|
|
/* The length of the frame stored in framebuf */
|
2012-01-24 14:02:24 +01:00
|
|
|
size_t framebuflen;
|
2012-02-16 12:54:30 +01:00
|
|
|
/* The number of bytes has been sent */
|
2012-01-24 14:02:24 +01:00
|
|
|
size_t framebufoff;
|
2014-01-26 14:01:27 +01:00
|
|
|
/* Marks the last position to send. This is used to implement
|
|
|
|
CONTINUATION */
|
|
|
|
size_t framebufmark;
|
2013-07-12 17:19:03 +02:00
|
|
|
} nghttp2_active_outbound_item;
|
2012-01-24 14:02:24 +01:00
|
|
|
|
2012-03-17 15:39:38 +01:00
|
|
|
/* Buffer length for inbound raw byte stream. */
|
2013-07-12 17:19:03 +02:00
|
|
|
#define NGHTTP2_INBOUND_BUFFER_LENGTH 16384
|
2012-02-07 17:25:26 +01:00
|
|
|
|
2013-07-12 17:19:03 +02:00
|
|
|
#define NGHTTP2_INITIAL_OUTBOUND_FRAMEBUF_LENGTH (NGHTTP2_DATA_PAYLOAD_LENGTH+8)
|
|
|
|
#define NGHTTP2_INITIAL_INBOUND_FRAMEBUF_LENGTH \
|
|
|
|
NGHTTP2_INITIAL_OUTBOUND_FRAMEBUF_LENGTH
|
|
|
|
#define NGHTTP2_INITIAL_NV_BUFFER_LENGTH 4096
|
2012-02-16 12:54:30 +01:00
|
|
|
|
2012-05-25 03:46:40 +02:00
|
|
|
/* Internal state when receiving incoming frame */
|
2012-01-24 14:02:24 +01:00
|
|
|
typedef enum {
|
2012-05-25 03:46:40 +02:00
|
|
|
/* Receiving frame header */
|
2014-01-26 07:44:43 +01:00
|
|
|
NGHTTP2_IB_READ_HEAD,
|
|
|
|
NGHTTP2_IB_READ_NBYTE,
|
|
|
|
NGHTTP2_IB_READ_HEADER_BLOCK,
|
|
|
|
NGHTTP2_IB_IGN_HEADER_BLOCK,
|
|
|
|
NGHTTP2_IB_IGN_PAYLOAD,
|
|
|
|
NGHTTP2_IB_FRAME_SIZE_ERROR,
|
|
|
|
NGHTTP2_IB_READ_SETTINGS,
|
|
|
|
NGHTTP2_IB_READ_GOAWAY_DEBUG,
|
2014-01-26 12:31:28 +01:00
|
|
|
NGHTTP2_IB_EXPECT_CONTINUATION,
|
|
|
|
NGHTTP2_IB_IGN_CONTINUATION,
|
2014-01-26 07:44:43 +01:00
|
|
|
NGHTTP2_IB_READ_DATA,
|
|
|
|
NGHTTP2_IB_IGN_DATA
|
2013-07-12 17:19:03 +02:00
|
|
|
} nghttp2_inbound_state;
|
2012-01-24 14:02:24 +01:00
|
|
|
|
|
|
|
typedef struct {
|
2013-09-28 10:59:24 +02:00
|
|
|
nghttp2_frame frame;
|
2014-01-26 07:44:43 +01:00
|
|
|
/* The received SETTINGS entry. The protocol says that we only cares
|
|
|
|
about the defined settings ID. If unknown ID is received, it is
|
|
|
|
subject to connection error */
|
|
|
|
nghttp2_settings_entry iv[5];
|
|
|
|
/* The number of entry filled in |iv| */
|
|
|
|
size_t niv;
|
|
|
|
/* How many bytes we still need to receive in the |buf| */
|
|
|
|
size_t left;
|
|
|
|
/* How many bytes we still need to receive for current frame */
|
|
|
|
size_t payloadleft;
|
2013-12-06 15:17:38 +01:00
|
|
|
nghttp2_inbound_state state;
|
2014-01-26 07:44:43 +01:00
|
|
|
/* TODO, remove this. Error code */
|
2012-05-25 03:46:40 +02:00
|
|
|
int error_code;
|
2014-01-26 07:44:43 +01:00
|
|
|
uint8_t buf[8];
|
|
|
|
/* How many bytes have been written to |buf| */
|
|
|
|
uint8_t buflen;
|
2013-07-12 17:19:03 +02:00
|
|
|
} nghttp2_inbound_frame;
|
2012-01-24 14:02:24 +01:00
|
|
|
|
2012-01-28 11:22:38 +01:00
|
|
|
typedef enum {
|
2013-07-12 17:19:03 +02:00
|
|
|
NGHTTP2_GOAWAY_NONE = 0,
|
2012-01-28 11:22:38 +01:00
|
|
|
/* Flag means GOAWAY frame is sent to the remote peer. */
|
2013-07-12 17:19:03 +02:00
|
|
|
NGHTTP2_GOAWAY_SEND = 0x1,
|
2012-01-28 11:22:38 +01:00
|
|
|
/* Flag means GOAWAY frame is received from the remote peer. */
|
2013-07-12 17:19:03 +02:00
|
|
|
NGHTTP2_GOAWAY_RECV = 0x2,
|
2012-02-18 13:55:40 +01:00
|
|
|
/* Flag means connection should be dropped after sending GOAWAY. */
|
2013-07-12 17:19:03 +02:00
|
|
|
NGHTTP2_GOAWAY_FAIL_ON_SEND = 0x4
|
|
|
|
} nghttp2_goaway_flag;
|
2012-01-28 11:22:38 +01:00
|
|
|
|
2013-07-12 17:19:03 +02:00
|
|
|
struct nghttp2_session {
|
|
|
|
nghttp2_map /* <nghttp2_stream*> */ streams;
|
2013-07-15 14:45:59 +02:00
|
|
|
/* Queue for outbound frames other than stream-creating HEADERS */
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_pq /* <nghttp2_outbound_item*> */ ob_pq;
|
2013-07-15 14:45:59 +02:00
|
|
|
/* Queue for outbound stream-creating HEADERS frame */
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_pq /* <nghttp2_outbound_item*> */ ob_ss_pq;
|
|
|
|
nghttp2_active_outbound_item aob;
|
|
|
|
nghttp2_inbound_frame iframe;
|
2014-01-26 09:53:04 +01:00
|
|
|
nghttp2_hd_deflater hd_deflater;
|
|
|
|
nghttp2_hd_inflater hd_inflater;
|
2013-12-06 15:17:38 +01:00
|
|
|
nghttp2_session_callbacks callbacks;
|
|
|
|
/* Sequence number of outbound frame to maintain the order of
|
|
|
|
enqueue if priority is equal. */
|
|
|
|
int64_t next_seq;
|
|
|
|
void *user_data;
|
|
|
|
/* In-flight SETTINGS values. NULL does not necessarily mean there
|
|
|
|
is no in-flight SETTINGS. */
|
|
|
|
nghttp2_settings_entry *inflight_iv;
|
|
|
|
/* The number of entries in |inflight_iv|. -1 if there is no
|
|
|
|
in-flight SETTINGS. */
|
|
|
|
ssize_t inflight_niv;
|
|
|
|
/* The number of outgoing streams. This will be capped by
|
|
|
|
remote_settings[NGHTTP2_SETTINGS_MAX_CONCURRENT_STREAMS]. */
|
|
|
|
size_t num_outgoing_streams;
|
|
|
|
/* The number of incoming streams. This will be capped by
|
|
|
|
local_settings[NGHTTP2_SETTINGS_MAX_CONCURRENT_STREAMS]. */
|
|
|
|
size_t num_incoming_streams;
|
2012-02-16 12:54:30 +01:00
|
|
|
/* The number of bytes allocated for nvbuf */
|
|
|
|
size_t nvbuflen;
|
2013-12-06 15:17:38 +01:00
|
|
|
/* Next Stream ID. Made unsigned int to detect >= (1 << 31). */
|
|
|
|
uint32_t next_stream_id;
|
|
|
|
/* The largest stream ID received so far */
|
|
|
|
int32_t last_recv_stream_id;
|
|
|
|
/* The largest stream ID which has been processed in some way. This
|
|
|
|
value will be used as last-stream-id when sending GOAWAY
|
|
|
|
frame. */
|
|
|
|
int32_t last_proc_stream_id;
|
|
|
|
/* Counter of unique ID of PING. Wraps when it exceeds
|
|
|
|
NGHTTP2_MAX_UNIQUE_ID */
|
|
|
|
uint32_t next_unique_id;
|
2013-11-28 15:26:34 +01:00
|
|
|
/* This is the value in GOAWAY frame received from remote endpoint. */
|
2013-07-15 14:45:59 +02:00
|
|
|
int32_t last_stream_id;
|
|
|
|
/* Current sender window size. This value is computed against the
|
|
|
|
current initial window size of remote endpoint. */
|
2013-08-08 18:31:15 +02:00
|
|
|
int32_t remote_window_size;
|
2013-07-15 14:45:59 +02:00
|
|
|
/* Keep track of the number of bytes received without
|
2013-10-30 15:43:40 +01:00
|
|
|
WINDOW_UPDATE. This could be negative after submitting negative
|
|
|
|
value to WINDOW_UPDATE. */
|
2013-07-15 14:45:59 +02:00
|
|
|
int32_t recv_window_size;
|
2013-10-12 10:02:37 +02:00
|
|
|
/* The amount of recv_window_size cut using submitting negative
|
|
|
|
value to WINDOW_UPDATE */
|
|
|
|
int32_t recv_reduction;
|
2013-08-08 17:58:52 +02:00
|
|
|
/* window size for local flow control. It is initially set to
|
|
|
|
NGHTTP2_INITIAL_CONNECTION_WINDOW_SIZE and could be
|
|
|
|
increased/decreased by submitting WINDOW_UPDATE. See
|
|
|
|
nghttp2_submit_window_update(). */
|
|
|
|
int32_t local_window_size;
|
2012-03-09 16:10:11 +01:00
|
|
|
/* Settings value received from the remote endpoint. We just use ID
|
|
|
|
as index. The index = 0 is unused. */
|
2013-07-12 17:19:03 +02:00
|
|
|
uint32_t remote_settings[NGHTTP2_SETTINGS_MAX+1];
|
2012-03-09 16:10:11 +01:00
|
|
|
/* Settings value of the local endpoint. */
|
2013-07-12 17:19:03 +02:00
|
|
|
uint32_t local_settings[NGHTTP2_SETTINGS_MAX+1];
|
|
|
|
/* Option flags. This is bitwise-OR of 0 or more of nghttp2_optmask. */
|
2012-05-08 15:59:34 +02:00
|
|
|
uint32_t opt_flags;
|
2013-12-06 15:17:38 +01:00
|
|
|
/* Nonzero if the session is server side. */
|
|
|
|
uint8_t server;
|
|
|
|
/* Flags indicating GOAWAY is sent and/or recieved. The flags are
|
|
|
|
composed by bitwise OR-ing nghttp2_goaway_flag. */
|
|
|
|
uint8_t goaway_flags;
|
|
|
|
/* Non-zero indicates connection-level flow control on remote side
|
|
|
|
is in effect. This will be disabled when WINDOW_UPDATE with
|
|
|
|
END_FLOW_CONTROL bit set is received. */
|
|
|
|
uint8_t remote_flow_control;
|
|
|
|
/* Non-zero indicates connection-level flow control on local side is
|
|
|
|
in effect. This will be disabled when WINDOW_UPDATE with
|
|
|
|
END_FLOW_CONTROL bit set is sent. */
|
|
|
|
uint8_t local_flow_control;
|
2012-01-31 13:32:46 +01:00
|
|
|
};
|
2012-01-24 14:02:24 +01:00
|
|
|
|
2012-05-11 15:58:12 +02:00
|
|
|
/* Struct used when updating initial window size of each active
|
|
|
|
stream. */
|
|
|
|
typedef struct {
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_session *session;
|
2012-05-11 15:58:12 +02:00
|
|
|
int32_t new_window_size, old_window_size;
|
2013-07-12 17:19:03 +02:00
|
|
|
} nghttp2_update_window_size_arg;
|
2012-05-11 15:58:12 +02:00
|
|
|
|
2012-01-24 14:02:24 +01:00
|
|
|
/* TODO stream timeout etc */
|
|
|
|
|
2012-02-02 15:19:01 +01:00
|
|
|
/*
|
2012-02-22 15:39:30 +01:00
|
|
|
* Returns nonzero value if |stream_id| is initiated by local
|
|
|
|
* endpoint.
|
2012-02-02 15:19:01 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_is_my_stream_id(nghttp2_session *session,
|
2012-02-02 15:19:01 +01:00
|
|
|
int32_t stream_id);
|
|
|
|
|
2012-01-29 11:07:31 +01:00
|
|
|
/*
|
2012-03-29 16:59:51 +02:00
|
|
|
* Adds frame |frame| to the outbound queue in |session|. The
|
2013-07-12 17:19:03 +02:00
|
|
|
* |frame_cat| must be either NGHTTP2_CTRL or NGHTTP2_DATA. If the
|
|
|
|
* |frame_cat| is NGHTTP2_CTRL, the |frame| must be a pointer to
|
|
|
|
* nghttp2_frame. If the |frame_cat| is NGHTTP2_DATA, it must be a
|
2014-01-27 13:22:33 +01:00
|
|
|
* pointer to nghttp2_private_data. |aux_data| is a pointer to the arbitrary
|
2012-03-29 16:59:51 +02:00
|
|
|
* data. Its interpretation is defined per the type of the frame. When
|
|
|
|
* this function succeeds, it takes ownership of |frame| and
|
|
|
|
* |aux_data|, so caller must not free them on success.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-22 15:39:30 +01:00
|
|
|
* Out of memory.
|
2012-01-29 11:07:31 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_add_frame(nghttp2_session *session,
|
|
|
|
nghttp2_frame_category frame_cat,
|
2012-03-29 16:59:51 +02:00
|
|
|
void *abs_frame, void *aux_data);
|
2012-01-24 14:02:24 +01:00
|
|
|
|
2012-02-22 15:39:30 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Adds RST_STREAM frame for the stream |stream_id| with the error
|
|
|
|
* code |error_code|. This is a convenient function built on top of
|
2013-07-12 17:19:03 +02:00
|
|
|
* nghttp2_session_add_frame() to add RST_STREAM easily.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-22 15:39:30 +01:00
|
|
|
* Out of memory.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_add_rst_stream(nghttp2_session *session,
|
2013-07-15 14:45:59 +02:00
|
|
|
int32_t stream_id,
|
|
|
|
nghttp2_error_code error_code);
|
2012-01-25 13:31:28 +01:00
|
|
|
|
2012-02-22 15:39:30 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Adds PING frame. This is a convenient functin built on top of
|
|
|
|
* nghttp2_session_add_frame() to add PING easily.
|
|
|
|
*
|
|
|
|
* If the |opaque_data| is not NULL, it must point to 8 bytes memory
|
|
|
|
* region of data. The data pointed by |opaque_data| is copied. It can
|
|
|
|
* be NULL. In this case, 8 bytes NULL is used.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-22 15:39:30 +01:00
|
|
|
* Out of memory.
|
|
|
|
*/
|
2013-07-15 14:45:59 +02:00
|
|
|
int nghttp2_session_add_ping(nghttp2_session *session, uint8_t flags,
|
|
|
|
uint8_t *opaque_data);
|
2012-01-27 15:05:29 +01:00
|
|
|
|
2012-02-22 15:39:30 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Adds GOAWAY frame with the last-stream-ID |last_stream_id| and the
|
|
|
|
* error code |error_code|. This is a convenient function built on top
|
|
|
|
* of nghttp2_session_add_frame() to add GOAWAY easily.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-22 15:39:30 +01:00
|
|
|
* Out of memory.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_add_goaway(nghttp2_session *session,
|
2013-07-15 14:45:59 +02:00
|
|
|
int32_t last_stream_id,
|
|
|
|
nghttp2_error_code error_code,
|
|
|
|
uint8_t *opaque_data, size_t opaque_data_len);
|
2012-01-28 11:22:38 +01:00
|
|
|
|
2012-02-25 16:12:32 +01:00
|
|
|
/*
|
|
|
|
* Adds WINDOW_UPDATE frame with stream ID |stream_id| and
|
2013-07-15 14:45:59 +02:00
|
|
|
* window-size-increment |window_size_increment|. This is a convenient
|
2013-07-12 17:19:03 +02:00
|
|
|
* function built on top of nghttp2_session_add_frame() to add
|
2012-02-25 16:12:32 +01:00
|
|
|
* WINDOW_UPDATE easily.
|
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-25 16:12:32 +01:00
|
|
|
* Out of memory.
|
|
|
|
*/
|
2013-07-15 14:45:59 +02:00
|
|
|
int nghttp2_session_add_window_update(nghttp2_session *session, uint8_t flags,
|
2012-02-25 16:12:32 +01:00
|
|
|
int32_t stream_id,
|
2013-07-15 14:45:59 +02:00
|
|
|
int32_t window_size_increment);
|
2012-02-25 16:12:32 +01:00
|
|
|
|
2013-10-27 11:22:51 +01:00
|
|
|
/*
|
|
|
|
* Adds SETTINGS frame.
|
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
|
|
|
* NGHTTP2_ERR_NOMEM
|
|
|
|
* Out of memory.
|
|
|
|
*/
|
|
|
|
int nghttp2_session_add_settings(nghttp2_session *session, uint8_t flags,
|
|
|
|
const nghttp2_settings_entry *iv, size_t niv);
|
|
|
|
|
2012-01-25 15:46:07 +01:00
|
|
|
/*
|
|
|
|
* Creates new stream in |session| with stream ID |stream_id|,
|
2013-07-15 14:45:59 +02:00
|
|
|
* priority |pri| and flags |flags|. NGHTTP2_FLAG_END_STREAM flag is
|
|
|
|
* set in |flags|, the sender of HEADERS will not send any further
|
|
|
|
* data in this stream. Since this function is called when initial
|
|
|
|
* HEADERS is sent or received, these flags are taken from it. The
|
|
|
|
* state of stream is set to |initial_state|. The |stream_user_data|
|
|
|
|
* is a pointer to the arbitrary user supplied data to be associated
|
|
|
|
* to this stream.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns a pointer to created new stream object, or
|
|
|
|
* NULL.
|
2012-01-25 15:46:07 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_stream* nghttp2_session_open_stream(nghttp2_session *session,
|
2012-01-28 16:16:51 +01:00
|
|
|
int32_t stream_id,
|
2013-07-15 14:45:59 +02:00
|
|
|
uint8_t flags, int32_t pri,
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_stream_state initial_state,
|
2012-02-03 17:37:21 +01:00
|
|
|
void *stream_user_data);
|
2012-01-24 14:02:24 +01:00
|
|
|
|
2012-01-25 17:04:01 +01:00
|
|
|
/*
|
2012-01-29 15:00:33 +01:00
|
|
|
* Closes stream whose stream ID is |stream_id|. The reason of closure
|
2013-07-15 14:45:59 +02:00
|
|
|
* is indicated by the |error_code|. When closing the stream,
|
2012-02-22 15:39:30 +01:00
|
|
|
* on_stream_close_callback will be called.
|
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_INVALID_ARGUMENT
|
2012-02-22 15:39:30 +01:00
|
|
|
* The specified stream does not exist.
|
2012-01-25 17:04:01 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_close_stream(nghttp2_session *session, int32_t stream_id,
|
2013-07-15 14:45:59 +02:00
|
|
|
nghttp2_error_code error_code);
|
2012-02-02 15:19:01 +01:00
|
|
|
|
2012-01-28 16:08:51 +01:00
|
|
|
/*
|
2012-02-22 15:39:30 +01:00
|
|
|
* If further receptions and transmissions over the stream |stream_id|
|
2013-07-15 14:45:59 +02:00
|
|
|
* are disallowed, close the stream with error code NGHTTP2_NO_ERROR.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it
|
|
|
|
* succeeds, or one of the following negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_INVALID_ARGUMENT
|
2012-02-22 15:39:30 +01:00
|
|
|
* The specified stream does not exist.
|
2012-01-28 16:08:51 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_close_stream_if_shut_rdwr(nghttp2_session *session,
|
|
|
|
nghttp2_stream *stream);
|
2012-01-28 16:08:51 +01:00
|
|
|
|
2013-07-15 14:45:59 +02:00
|
|
|
|
2014-01-26 07:44:43 +01:00
|
|
|
int nghttp2_session_end_request_headers_received(nghttp2_session *session,
|
2014-01-29 13:23:13 +01:00
|
|
|
nghttp2_frame *frame,
|
|
|
|
nghttp2_stream *stream);
|
2014-01-26 07:44:43 +01:00
|
|
|
|
|
|
|
int nghttp2_session_end_response_headers_received(nghttp2_session *session,
|
2014-01-29 13:23:13 +01:00
|
|
|
nghttp2_frame *frame,
|
|
|
|
nghttp2_stream *stream);
|
2014-01-26 07:44:43 +01:00
|
|
|
|
|
|
|
int nghttp2_session_end_headers_received(nghttp2_session *session,
|
2014-01-29 13:23:13 +01:00
|
|
|
nghttp2_frame *frame,
|
|
|
|
nghttp2_stream *stream);
|
2014-01-26 07:44:43 +01:00
|
|
|
|
2013-07-25 14:07:38 +02:00
|
|
|
int nghttp2_session_on_request_headers_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame);
|
2012-01-25 15:46:07 +01:00
|
|
|
|
2013-07-25 14:07:38 +02:00
|
|
|
int nghttp2_session_on_response_headers_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame,
|
|
|
|
nghttp2_stream *stream);
|
2013-07-15 14:45:59 +02:00
|
|
|
|
2013-07-25 14:07:38 +02:00
|
|
|
int nghttp2_session_on_push_response_headers_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame,
|
|
|
|
nghttp2_stream *stream);
|
2013-07-24 18:49:05 +02:00
|
|
|
|
2012-01-25 15:46:07 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Called when HEADERS is received, assuming |frame| is properly
|
|
|
|
* initialized. This function does first validate received frame and
|
|
|
|
* then open stream and call callback functions.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-22 15:39:30 +01:00
|
|
|
* Out of memory.
|
2012-01-25 15:46:07 +01:00
|
|
|
*/
|
2013-07-15 14:45:59 +02:00
|
|
|
int nghttp2_session_on_headers_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame,
|
|
|
|
nghttp2_stream *stream);
|
2012-01-25 15:46:07 +01:00
|
|
|
|
2013-07-22 17:11:39 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Called when PRIORITY is received, assuming |frame| is properly
|
|
|
|
* initialized.
|
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
|
|
|
* NGHTTP2_ERR_NOMEM
|
|
|
|
* Out of memory.
|
|
|
|
*/
|
|
|
|
int nghttp2_session_on_priority_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame);
|
|
|
|
|
2012-01-27 15:22:27 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Called when RST_STREAM is received, assuming |frame| is properly
|
|
|
|
* initialized.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
2013-10-27 11:22:51 +01:00
|
|
|
* This function returns 0 if it succeeds, or one the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
|
|
|
* TBD
|
2012-01-27 15:22:27 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_on_rst_stream_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame);
|
2012-01-27 15:22:27 +01:00
|
|
|
|
2012-01-31 17:12:26 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Called when SETTINGS is received, assuming |frame| is properly
|
2013-10-27 11:22:51 +01:00
|
|
|
* initialized. If |noack| is non-zero, SETTINGS with ACK will not be
|
|
|
|
* submitted. If |frame| has NGHTTP2_FLAG_ACK flag set, no SETTINGS
|
|
|
|
* with ACK will not be submitted regardless of |noack|.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
2013-10-27 11:22:51 +01:00
|
|
|
* This function returns 0 if it succeeds, or one the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
|
|
|
* NGHTTP2_ERR_NOMEM
|
|
|
|
* Out of memory
|
|
|
|
* NGHTTP2_ERR_PAUSE
|
|
|
|
* Callback function returns NGHTTP2_ERR_PAUSE
|
|
|
|
* NGHTTP2_ERR_CALLBACK_FAILURE
|
|
|
|
* The read_callback failed
|
2012-01-31 17:12:26 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_on_settings_received(nghttp2_session *session,
|
2013-10-27 11:22:51 +01:00
|
|
|
nghttp2_frame *frame,
|
|
|
|
int noack);
|
2013-07-24 18:49:05 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Called when PUSH_PROMISE is received, assuming |frame| is properly
|
|
|
|
* initialized.
|
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
|
|
|
* NGHTTP2_ERR_NOMEM
|
|
|
|
* Out of memory.
|
|
|
|
*/
|
|
|
|
int nghttp2_session_on_push_promise_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame);
|
2012-01-31 17:12:26 +01:00
|
|
|
|
2012-01-27 15:37:47 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Called when PING is received, assuming |frame| is properly
|
2012-02-22 15:39:30 +01:00
|
|
|
* initialized.
|
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-22 15:39:30 +01:00
|
|
|
* Out of memory.
|
2012-01-27 15:37:47 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_on_ping_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame);
|
2012-01-27 15:37:47 +01:00
|
|
|
|
2012-01-28 11:22:38 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Called when GOAWAY is received, assuming |frame| is properly
|
2012-02-22 15:39:30 +01:00
|
|
|
* initialized.
|
|
|
|
*
|
|
|
|
* This function returns 0 and never fail.
|
2012-01-28 11:22:38 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_on_goaway_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame);
|
2012-01-28 11:22:38 +01:00
|
|
|
|
2012-01-27 11:10:13 +01:00
|
|
|
/*
|
2013-07-15 14:45:59 +02:00
|
|
|
* Called when WINDOW_UPDATE is recieved, assuming |frame| is properly
|
|
|
|
* initialized.
|
2012-02-25 16:12:32 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-25 16:12:32 +01:00
|
|
|
* Out of memory.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_on_window_update_received(nghttp2_session *session,
|
|
|
|
nghttp2_frame *frame);
|
2012-02-25 16:12:32 +01:00
|
|
|
|
2012-01-29 08:27:00 +01:00
|
|
|
/*
|
2014-01-27 14:13:41 +01:00
|
|
|
* Called when DATA is received, assuming |frame| is properly
|
|
|
|
* initialized.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-02-22 15:39:30 +01:00
|
|
|
* Out of memory.
|
2014-01-27 14:13:41 +01:00
|
|
|
* NGHTTP2_ERR_CALLBACK_FAILURE
|
|
|
|
* The callback function failed.
|
2012-01-29 08:27:00 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
int nghttp2_session_on_data_received(nghttp2_session *session,
|
2014-01-27 14:13:41 +01:00
|
|
|
nghttp2_frame *frame);
|
2012-01-29 08:27:00 +01:00
|
|
|
|
2012-01-25 17:04:01 +01:00
|
|
|
/*
|
2013-07-12 17:19:03 +02:00
|
|
|
* Returns nghttp2_stream* object whose stream ID is |stream_id|. It
|
2012-01-25 17:04:01 +01:00
|
|
|
* could be NULL if such stream does not exist.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_stream* nghttp2_session_get_stream(nghttp2_session *session,
|
2012-01-25 17:04:01 +01:00
|
|
|
int32_t stream_id);
|
|
|
|
|
2012-01-26 17:17:40 +01:00
|
|
|
/*
|
2012-02-22 15:39:30 +01:00
|
|
|
* Packs DATA frame |frame| in wire frame format and stores it in
|
2012-02-16 12:54:30 +01:00
|
|
|
* |*buf_ptr|. The capacity of |*buf_ptr| is |*buflen_ptr|
|
|
|
|
* length. This function expands |*buf_ptr| as necessary to store
|
|
|
|
* given |frame|. It packs header in first 8 bytes. Remaining bytes
|
2012-02-22 15:58:33 +01:00
|
|
|
* are the DATA apyload and are filled using |frame->data_prd|. The
|
|
|
|
* length of payload is at most |datamax| bytes.
|
2012-02-22 15:39:30 +01:00
|
|
|
*
|
|
|
|
* This function returns the size of packed frame if it succeeds, or
|
|
|
|
* one of the following negative error codes:
|
|
|
|
*
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_DEFERRED
|
2012-02-22 15:39:30 +01:00
|
|
|
* The DATA frame is postponed.
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_TEMPORAL_CALLBACK_FAILURE
|
2012-05-12 11:19:05 +02:00
|
|
|
* The read_callback failed (stream error).
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_NOMEM
|
2012-05-12 11:19:05 +02:00
|
|
|
* Out of memory.
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_ERR_CALLBACK_FAILURE
|
2012-05-12 11:19:05 +02:00
|
|
|
* The read_callback failed (session error).
|
2012-01-26 17:17:40 +01:00
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
ssize_t nghttp2_session_pack_data(nghttp2_session *session,
|
2012-02-16 12:54:30 +01:00
|
|
|
uint8_t **buf_ptr, size_t *buflen_ptr,
|
2012-02-22 15:58:33 +01:00
|
|
|
size_t datamax,
|
2014-01-27 13:22:33 +01:00
|
|
|
nghttp2_private_data *frame);
|
2012-01-26 17:17:40 +01:00
|
|
|
|
2012-01-27 15:05:29 +01:00
|
|
|
/*
|
|
|
|
* Returns top of outbound frame queue. This function returns NULL if
|
|
|
|
* queue is empty.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_outbound_item* nghttp2_session_get_ob_pq_top(nghttp2_session *session);
|
2012-01-27 15:05:29 +01:00
|
|
|
|
2012-02-05 16:14:19 +01:00
|
|
|
/*
|
|
|
|
* Pops and returns next item to send. If there is no such item,
|
|
|
|
* returns NULL. This function takes into account max concurrent
|
|
|
|
* streams. That means if session->ob_pq is empty but
|
|
|
|
* session->ob_ss_pq has item and max concurrent streams is reached,
|
|
|
|
* then this function returns NULL.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_outbound_item* nghttp2_session_pop_next_ob_item
|
|
|
|
(nghttp2_session *session);
|
2012-02-05 16:14:19 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Returns next item to send. If there is no such item, this function
|
|
|
|
* returns NULL. This function takes into account max concurrent
|
|
|
|
* streams. That means if session->ob_pq is empty but
|
|
|
|
* session->ob_ss_pq has item and max concurrent streams is reached,
|
|
|
|
* then this function returns NULL.
|
|
|
|
*/
|
2013-07-12 17:19:03 +02:00
|
|
|
nghttp2_outbound_item* nghttp2_session_get_next_ob_item
|
|
|
|
(nghttp2_session *session);
|
2012-02-05 16:14:19 +01:00
|
|
|
|
2012-03-10 10:41:01 +01:00
|
|
|
/*
|
|
|
|
* Updates local settings with the |iv|. The number of elements in the
|
|
|
|
* array pointed by the |iv| is given by the |niv|. This function
|
|
|
|
* assumes that the all settings_id member in |iv| are in range 1 to
|
2013-07-12 17:19:03 +02:00
|
|
|
* NGHTTP2_SETTINGS_MAX, inclusive.
|
2013-08-08 17:58:52 +02:00
|
|
|
*
|
|
|
|
* While updating individual stream's local window size, if the window
|
|
|
|
* size becomes strictly larger than NGHTTP2_MAX_WINDOW_SIZE,
|
|
|
|
* RST_STREAM is issued against such a stream.
|
|
|
|
*
|
|
|
|
* This function returns 0 if it succeeds, or one of the following
|
|
|
|
* negative error codes:
|
|
|
|
*
|
|
|
|
* NGHTTP2_ERR_NOMEM
|
|
|
|
* Out of memory
|
2012-03-10 10:41:01 +01:00
|
|
|
*/
|
2013-08-08 17:58:52 +02:00
|
|
|
int nghttp2_session_update_local_settings(nghttp2_session *session,
|
|
|
|
nghttp2_settings_entry *iv,
|
|
|
|
size_t niv);
|
2012-03-10 10:41:01 +01:00
|
|
|
|
2013-08-09 16:40:41 +02:00
|
|
|
/*
|
|
|
|
* Re-prioritize |stream|. The new priority is |pri|.
|
|
|
|
*/
|
|
|
|
void nghttp2_session_reprioritize_stream
|
|
|
|
(nghttp2_session *session, nghttp2_stream *stream, int32_t pri);
|
|
|
|
|
2013-07-12 17:19:03 +02:00
|
|
|
#endif /* NGHTTP2_SESSION_H */
|