blob: 2e4048d732d2477be0eb7c2444d26c00a7e717a2 [file] [log] [blame]
.. Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
.. default-domain:: c
============================
TSMimeHdrFieldValueStringGet
============================
Get HTTP MIME header values.
Synopsis
========
`#include <ts/ts.h>`
.. function:: const char* TSMimeHdrFieldValueStringGet(TSMBuffer bufp, TSMLoc hdr, TSMLoc field, int idx, int* value_len_ptr)
.. function:: int TSMimeHdrFieldValueIntGet(TSMBuffer bufp, TSMLoc hdr, TSMLoc field, int idx)
.. function:: int64_t TSMimeHdrFieldValueInt64Get(TSMBuffer bufp, TSMLoc hdr, TSMLoc field, int idx)
.. function:: unsigned int TSMimeHdrFieldValueUintGet(TSMBuffer bufp, TSMLoc hdr, TSMLoc field, int idx)
.. function:: time_t TSMimeHdrFieldValueDateGet(TSMBuffer bufp, TSMLoc hdr, TSMLoc field)
Description
===========
MIME headers and fields can be components of request headers,
response headers, or standalone headers created within a Traffic
Server plugin. The functions here are all used to access header
values of specific types, but it is up to the caller to know if a
header has appropriate semantics for the API used. For all but
:func:`TSMimeHdrFieldValueStringGet`, an appropriate data conversion
algorithm is applied to the header field string.
All the APIs take a :type:`TSMBuffer` marshal buffer argument, and
a :type:`TSMLoc` argument indicating the location of the HTTP
headers. The required :data:`field` argument is the locator of a
specific header value, as returned by an accessor function such as
:func:`TSMimeHdrFieldFind`.
Within the header field, comma-separated values can be retrieved with an index
(:data:`idx`) ranging from 0 to the maximum number of fields for this value; this
maximum is retrieved using :func:`TSMimeHdrFieldValuesCount`. An :data:`idx` value of
``-1`` has the semantics of retrieving the entire header value, regardless of
how many comma-separated values there are. If a header is not comma-separated,
an :data:`idx` of :data:`0` or :data:`-1` are the same, but the latter is
preferred.
:func:`TSMimeHdrFieldValueStringGet` returns a pointer to the header
value, and populated :data:`value_len_ptr` with the length of the
value in bytes. The returned header value is not NUL-terminated.
Return values
=============
All functions returns the header value with a type matching the respective
function name. Using :func:`TSMimeHdrFieldValueDateGet` on a header which
does not have date-time semantics always returns :data:`0`.
Examples
========
This examples show how to retrieve and copy a specific header.
::
#include <string.h>
#include <ts/ts.h>
int
get_content_type(TSHttpTxn txnp, char* buf, size_t buf_size)
{
TSMBuffer bufp;
TSMLoc hdrs;
TSMLoc ctype_field;
int len = -1;
if (TS_SUCCESS == TSHttpTxnServerRespGet(txnp, &bufp, &hdrs)) {
ctype_field = TSMimeHdrFieldFind(bufp, hdrs, TS_MIME_FIELD_CONTENT_TYPE, TS_MIME_LEN_CONTENT_TYPE);
if (TS_NULL_MLOC != ctype_field) {
const char* str = TSMimeHdrFieldValueStringGet(bufp, hdrs, ctype_field, -1, &len);
if (len > buf_size)
len = buf_size;
memcpy(buf, str, len);
TSHandleMLocRelease(bufp, hdrs, ctype_field);
}
TSHandleMLocRelease(bufp, TS_NULL_MLOC, hdrs);
}
return len;
}
See also
========
:manpage:`TSAPI(3ts)`, :manpage:`TSMBufferCreate(3ts)`, :manpage:`TSMimeHdrFieldValuesCount(3ts)`