From 425a54a9380083e77742508d5fcb171f193c2171 Mon Sep 17 00:00:00 2001
From: Tatsuhiro Tsujikawa
Date: Sat, 1 Feb 2014 21:24:57 +0900
Subject: [PATCH] Update doc
---
_sources/apiref.txt | 34 ++++++++++++++++++++++++++++++++++
apiref.html | 32 ++++++++++++++++++++++++++++++++
genindex.html | 12 ++++++++++--
nghttp2.h.html | 38 ++++++++++++++++++++++++++++++++++++++
objects.inv | Bin 2114 -> 2129 bytes
searchindex.js | 2 +-
6 files changed, 115 insertions(+), 3 deletions(-)
diff --git a/_sources/apiref.txt b/_sources/apiref.txt
index e7604e82..a41bb6bf 100644
--- a/_sources/apiref.txt
+++ b/_sources/apiref.txt
@@ -997,6 +997,20 @@ Types (structs, unions and typedefs)
The *name* may be ``NULL`` if the *namelen* is 0. The same thing
can be said about the *value*.
+ Please note that nghttp2 library does not perform any validity
+ check against the *name* and the *value*. For example, the
+ *namelen* could be 0, and/or the *value* contains ``0x0a`` or
+ ``0x0d``. The application must check them if it matters. The
+ helper function `nghttp2_check_header_name()` and
+ `nghttp2_check_header_value()` provide simple validation against
+ HTTP2 header field construction rule.
+
+ One more thing to note is that the *value* may contain ``NULL``
+ (``0x00``) characters. It is used to concatenate header values
+ which share the same header field name. The application should
+ split these values if it wants to get individual value. This
+ concatenation is used in order to keep the ordering of headers.
+
If the application uses `nghttp2_session_mem_recv()`, it can return
:macro:`NGHTTP2_ERR_PAUSE` to make `nghttp2_session_mem_recv()`
return without processing further input bytes. The memory pointed
@@ -2007,4 +2021,24 @@ Functions
Returns nonzero if the :type:`nghttp2_error` library error code
*lib_error* is fatal.
+.. function:: int nghttp2_check_header_name(const uint8_t *name, size_t len)
+
+
+ Returns nonzero if HTTP header field name *name* of length *len* is
+ valid according to
+ http://tools.ietf.org/html/draft-ietf-httpbis-p1-messaging-25#section-3.2
+
+ Because this is a header field name in HTTP2, the upper cased alphabet
+ is treated as error.
+
+.. function:: int nghttp2_check_header_value(const uint8_t *value, size_t len)
+
+
+ Returns nonzero if HTTP header field value *value* of length *len*
+ is valid according to
+ http://tools.ietf.org/html/draft-ietf-httpbis-p1-messaging-25#section-3.2
+
+ Because this is HTTP2 header field value, it can contain NULL
+ character (0x00).
+
diff --git a/apiref.html b/apiref.html
index 38eb1f40..e53e67ed 100644
--- a/apiref.html
+++ b/apiref.html
@@ -1502,6 +1502,18 @@ is an error in decompression,
invoked.
The name may be NULL if the namelen is 0. The same thing
can be said about the value.
+Please note that nghttp2 library does not perform any validity
+check against the name and the value. For example, the
+namelen could be 0, and/or the value contains 0x0a or
+0x0d. The application must check them if it matters. The
+helper function nghttp2_check_header_name() and
+nghttp2_check_header_value() provide simple validation against
+HTTP2 header field construction rule.
+One more thing to note is that the value may contain NULL
+(0x00) characters. It is used to concatenate header values
+which share the same header field name. The application should
+split these values if it wants to get individual value. This
+concatenation is used in order to keep the ordering of headers.
If the application uses nghttp2_session_mem_recv(), it can return
NGHTTP2_ERR_PAUSE to make nghttp2_session_mem_recv()
return without processing further input bytes. The memory pointed
@@ -2532,6 +2544,26 @@ int nghttp2_is_fatal(int lib_error
lib_error is fatal.
+
+
+Returns nonzero if HTTP header field name name of length len is
+valid according to
+http://tools.ietf.org/html/draft-ietf-httpbis-p1-messaging-25#section-3.2
+Because this is a header field name in HTTP2, the upper cased alphabet
+is treated as error.
+
+
+
+
+Returns nonzero if HTTP header field value value of length len
+is valid according to
+http://tools.ietf.org/html/draft-ietf-httpbis-p1-messaging-25#section-3.2
+Because this is HTTP2 header field value, it can contain NULL
+character (0x00).
+
+
diff --git a/genindex.html b/genindex.html
index 182375d0..f0a27133 100644
--- a/genindex.html
+++ b/genindex.html
@@ -151,6 +151,14 @@
+ nghttp2_check_header_name (C function)
+
+
+
+ nghttp2_check_header_value (C function)
+
+
+
NGHTTP2_CLIENT_CONNECTION_HEADER (C macro)
@@ -602,12 +610,12 @@
nghttp2_nv.value (C member)
+
+
- nghttp2_nv.valuelen (C member)
- |
-
- nghttp2_nv_compare_name (C function)
diff --git a/nghttp2.h.html b/nghttp2.h.html
index 859c7f89..95d38e16 100644
--- a/nghttp2.h.html
+++ b/nghttp2.h.html
@@ -1242,6 +1242,20 @@
* The |name| may be ``NULL`` if the |namelen| is 0. The same thing
* can be said about the |value|.
*
+ * Please note that nghttp2 library does not perform any validity
+ * check against the |name| and the |value|. For example, the
+ * |namelen| could be 0, and/or the |value| contains ``0x0a`` or
+ * ``0x0d``. The application must check them if it matters. The
+ * helper function `nghttp2_check_header_name()` and
+ * `nghttp2_check_header_value()` provide simple validation against
+ * HTTP2 header field construction rule.
+ *
+ * One more thing to note is that the |value| may contain ``NULL``
+ * (``0x00``) characters. It is used to concatenate header values
+ * which share the same header field name. The application should
+ * split these values if it wants to get individual value. This
+ * concatenation is used in order to keep the ordering of headers.
+ *
* If the application uses `nghttp2_session_mem_recv()`, it can return
* :enum:`NGHTTP2_ERR_PAUSE` to make `nghttp2_session_mem_recv()`
* return without processing further input bytes. The memory pointed
@@ -2448,6 +2462,30 @@
*/
int nghttp2_is_fatal(int lib_error);
+/**
+ * @function
+ *
+ * Returns nonzero if HTTP header field name |name| of length |len| is
+ * valid according to
+ * http://tools.ietf.org/html/draft-ietf-httpbis-p1-messaging-25#section-3.2
+ *
+ * Because this is a header field name in HTTP2, the upper cased alphabet
+ * is treated as error.
+ */
+int nghttp2_check_header_name(const uint8_t *name, size_t len);
+
+/**
+ * @function
+ *
+ * Returns nonzero if HTTP header field value |value| of length |len|
+ * is valid according to
+ * http://tools.ietf.org/html/draft-ietf-httpbis-p1-messaging-25#section-3.2
+ *
+ * Because this is HTTP2 header field value, it can contain NULL
+ * character (0x00).
+ */
+int nghttp2_check_header_value(const uint8_t *value, size_t len);
+
#ifdef __cplusplus
}
#endif
diff --git a/objects.inv b/objects.inv
index 32755a762e2a3ba9f03c737d85a30c502f91fe80..618ff7d2912a1ccaa19621b8c80eeddc22a11471 100644
GIT binary patch
delta 2023
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
FppvW^`;rr%VRQ`iwc8mQ-gu!VNd4Q
zZ;O|~c2JAiQ!0ss)UEEXzptfJ8b(RTelChK{1W>+7B4>kwaDH-pW1&Y$MO{avDlq~zMR-;$MVHr3qOl;wr@WA=i>7xbN%AF+b2qFo9gCQ
z)zCHSxT;I|BtOX02Xnghv#L1KEKg5S!Ib12vt(+eZdP(u&VF1m%-Dhz1ve+~<9O!>
zKMDnY+2{U=(SIc6#wTI_KdhB6MAe8*m)2%GVPiMLA+D>NYp0v$s?P?Yj{Y6vAlU4Y
z`60`Pn=IcmHfeHMM#-U|EGhH%kH>c#)J>PzrfP88EE{3b*4C+Ey%NX8Sh~p6OIstcK;nlS)x>3zH*x}01;U7JOBCv^nU~5~hg&4b0zs&;WqS~FJ
z@-B}i{NBxMu)Kg$=VQI$nU1&JTDD6x`jyxYfRRkmA!cpa)^lDEmfe~pNG(luRm4}D
zWT`V-K38W^iS}pMj{Eq@KmAsW^NN?#X*Tj|daViZ?ockB>#
zWT8OR*ZWGBV#EKsM#&Coj;M1JASakPDvLtKFy?ZC;mwg`d6ec+`7XgA8uRDD
z{f_O^oV6J-i+n;p*lrhprsY!A;9N{YV&e)1b6(@xmVrY1hD##rGCyU0VmLHB{E9ND
zsDJwy0!fZstN?g0+wV@7A2VwI4YK!nir9{B>aGstdB7EM=`^&*v^Hdet!}F45H#dm
zDJI5#IE+-OsRW<&oBB$c9d*@Fa9Eu)Obe}8tgTD81nN9TJ2O4{0y=!VV5UdHjD}wPNwj1(8vmYpnr8UPGsMMUBm|Cq+c&cr5
z2U|5erJ&ktZv)AJr9iwRQM+AOKSp&C;Jo%}Qk^i4Xp|);Q-J^-W;Vn=Wc|Y9MYiJ}
z2@*Lx>iw})U22nmyy?E-U0~q-$bb2y*b>|6c8!b|Vy&>|iTBzK@5+hkZ6xG8mi8gl
z4`^})rI7DtK|Mc|M;VBPfpyH`@b#vg2;2RS7*XAxpyZp5inpa|E{TB{Xp{iJP(l*S>cJP-e$Ou@&y2oZ
z197x+<}NSsWdv^&$~1+NQ0}G(SAy&PFD0UItevqqpk7<*tNKP&17cfy11gRdn!4$Ds}+6rR>+%`u6HhqriKj+l0b$)K6>_o
zd{Lq#(HY%F?&LDIk=z)C$F}zVrg;e=MNF=Iq7H~UN_#dQyUw
z!lq>siMv*XHx;BPTYt&&QzOq3L0D3(9+`eoC8(LL)6hb0KoE4Txw-rbREs}PKueLE
z8w{-A!ac6);|MwvkOsZ}TAWMc;^%VU{iouG3aq>-sAPpLFhD4wBcYTXVlY;Ic8DpH8gEyQ
qZK_cwDjMPh8+1c4GzALSDf1yC+ee!d8~+dIz |