TSHttpTxnClientStreamPriorityGet¶
Synopsis¶
#include <ts/ts.h>
-
TSReturnCode
TSHttpTxnClientStreamPriorityGet
(TSHttpTxn txnp, TSHttpPriority *priority)¶
Description¶
Retrieve the priority information for the HTTP stream associated with the
provided transaction. The resultant priority information is populated in the
priority
output variable. The TSHttpPriority
type is designed to be
agnostic of the various HTTP protocol versions that support HTTP streams. The
user should pass a pointer casted to TSHttpPriority
from a previously
allocated TSHttp2Priority
structure. This design anticipates future support
for HTTP versions that support streams, such as HTTP/3.
The TSHttp2Priority
structure has the following declaration:
typedef struct {
uint8_t priority_type; /** HTTP_PROTOCOL_TYPE_HTTP_2 */
int32_t stream_dependency;
uint8_t weight;
} TSHttp2Priority;
In a call to TSHttpTxnClientStreamPriorityGet
, the dependency and weight
will be populated in the stream_dependency
and weight
members,
respectively. If the stream associated with the given transaction has no
dependency, then the stream_dependency
output parameter will be populated
with -1
and the value of weight
will be meaningless. See RFC 7540
section 5.3 for details concerning HTTP/2 stream priority.
This API returns an error if the provided transaction is not an HTTP/2 transaction.