.TH "globus_xio_http_driver_cntls" 3 "Version 6.6" "globus_xio" \" -*- nroff -*-
.ad l
.nh
.SH NAME
globus_xio_http_driver_cntls \- Attributes and Cntls
.PP
 \- Attributes and Cntls\&.  

.SH SYNOPSIS
.br
.PP
.SS "Enumerations"

.in +1c
.ti -1c
.RI "enum \fBglobus_xio_http_handle_cmd_t\fP { \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HEADER\fP, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_STATUS_CODE\fP, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_REASON_PHRASE\fP, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HTTP_VERSION\fP, \fBGLOBUS_XIO_HTTP_HANDLE_SET_END_OF_ENTITY\fP, \fBGLOBUS_XIO_HTTP_HANDLE_SET_REQUEST_HEADER\fP }"
.br
.ti -1c
.RI "enum \fBglobus_xio_http_attr_cmd_t\fP { \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_METHOD\fP, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HTTP_VERSION\fP, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HEADER\fP, \fBGLOBUS_XIO_HTTP_ATTR_DELAY_WRITE_HEADER\fP, \fBGLOBUS_XIO_HTTP_GET_REQUEST\fP, \fBGLOBUS_XIO_HTTP_GET_RESPONSE\fP }"
.br
.in -1c
.SS "Functions"

.in +1c
.ti -1c
.RI "globus_result_t \fBglobus_xio_handle_cntl\fP (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HEADER\fP, const char *header_name, const char *header_value)"
.br
.ti -1c
.RI "globus_result_t \fBglobus_xio_handle_cntl\fP (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_STATUS_CODE\fP, int status)"
.br
.ti -1c
.RI "globus_result_t \fBglobus_xio_handle_cntl\fP (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_REASON_PHRASE\fP, const char *reason)"
.br
.ti -1c
.RI "globus_result_t \fBglobus_xio_handle_cntl\fP (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HTTP_VERSION\fP, \fBglobus_xio_http_version_t\fP version)"
.br
.ti -1c
.RI "globus_result_t \fBglobus_xio_handle_cntl\fP (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_END_OF_ENTITY\fP)"
.br
.ti -1c
.RI "globus_result_t \fBglobus_xio_attr_cntl\fP (attr, driver, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_METHOD\fP, const char *method)"
.br
.ti -1c
.RI "globus_result_t \fBglobus_xio_attr_cntl\fP (attr, driver, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HTTP_VERSION\fP, \fBglobus_xio_http_version_t\fP version)"
.br
.ti -1c
.RI "globus_result_t \fBglobus_xio_attr_cntl\fP (attr, driver, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HEADER\fP, const char *header_name, const char *header_value)"
.br
.in -1c
.SH "Detailed Description"
.PP 
Attributes and Cntls\&. 

HTTP driver specific attrs and cntls\&.
.PP
\fBSee also\fP
.RS 4
\fBglobus_xio_attr_cntl()\fP 
.PP
\fBglobus_xio_handle_cntl()\fP 
.RE
.PP

.SH "Enumeration Type Documentation"
.PP 
.SS "enum \fBglobus_xio_http_attr_cmd_t\fP"
HTTP driver specific attribute and data descriptor cntls 
.PP
\fBEnumerator\fP
.in +1c
.TP
\fB\fIGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_METHOD \fP\fP
See usage for: \fBglobus_xio_attr_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HTTP_VERSION \fP\fP
See usage for: \fBglobus_xio_attr_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HEADER \fP\fP
See usage for: \fBglobus_xio_attr_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_ATTR_DELAY_WRITE_HEADER \fP\fP
See usage for: \fBglobus_xio_attr_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_GET_REQUEST \fP\fP
See usage for: \fBglobus_xio_data_descriptor_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_GET_RESPONSE \fP\fP
See usage for: \fBglobus_xio_data_descriptor_cntl \fP 
.SS "enum \fBglobus_xio_http_handle_cmd_t\fP"
HTTP driver specific cntls 
.PP
\fBEnumerator\fP
.in +1c
.TP
\fB\fIGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HEADER \fP\fP
See usage for: \fBglobus_xio_handle_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_STATUS_CODE \fP\fP
See usage for: \fBglobus_xio_handle_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_REASON_PHRASE \fP\fP
See usage for: \fBglobus_xio_handle_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HTTP_VERSION \fP\fP
See usage for: \fBglobus_xio_handle_cntl \fP 
.TP
\fB\fIGLOBUS_XIO_HTTP_HANDLE_SET_END_OF_ENTITY \fP\fP
See usage for: \fBglobus_xio_handle_cntl \fP 
.SH "Function Documentation"
.PP 
.SS "globus_result_t globus_xio_attr_cntl (attr, driver, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HEADER\fP, const char * header_name, const char * header_value)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Set the value of an HTTP request header\&.
.PP
\fBParameters\fP
.RS 4
\fIheader_name\fP Name of the HTTP header to set\&. 
.br
\fIheader_value\fP Value of the HTTP header
.RE
.PP
Certain headers will cause the HTTP driver to behave differently than normal\&. This must be called before
.PP
.IP "\(bu" 2
Transfer-Encoding: {identity|chunked} Override the default transfer encoding\&. If a server knows the exact length of the message body, or does not intend to support persistent connections, it may set this header to be 'identity'\&.
.br

.br
 If this is set to 'identity' and any of the following are true, then the connection will be closed after the end of the message is sent: 
.br

.br
.IP "  \(bu" 4
A Content-Length header is not present
.IP "  \(bu" 4
The HTTP version is set to 'HTTP/1\&.0'
.IP "  \(bu" 4
The Connection header is set to 'close' Attempts to set this to 'chunked' with an 'HTTP/1\&.0' client will fail with a GLOBUS_XIO_ERROR_HTTP_INVALID_HEADER error\&.
.PP

.IP "\(bu" 2
Content-Length: 1*Digit
.IP "  \(bu" 4
Provide a content length for the response message\&. If the 'chunked' transfer encoding is being used, then this header will be silently ignored by the HTTP driver\&.
.PP

.IP "\(bu" 2
Connection: close
.IP "  \(bu" 4
If present in the server response, the connection will be closed after the end of the data response is written\&. Otherwise, when persistent connections are enabled, the connection \fImay\fP be left open by the driver\&. Persistent connections are not yet implemented\&. 
.PP

.PP

.SS "globus_result_t globus_xio_attr_cntl (attr, driver, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_HTTP_VERSION\fP, \fBglobus_xio_http_version_t\fP version)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Set the HTTP version to use for a client request\&.
.PP
\fBParameters\fP
.RS 4
\fIversion\fP The HTTP version to use for the client request\&.
.RE
.PP
If the client is using HTTP/1\&.0 in a request which will send a request message body (such as a POST or PUT), then the client MUST set the 'Content-Length' HTTP header to be the length of the message\&. If this attribute is not present, then the default of GLOBUS_XIO_HTTP_VERSION_1_1 will be used\&.
.PP
This attribute is ignored when opening the server side of an HTTP connection\&. 
.SS "globus_result_t globus_xio_attr_cntl (attr, driver, \fBGLOBUS_XIO_HTTP_ATTR_SET_REQUEST_METHOD\fP, const char * method)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Set the HTTP method to use for a client request\&.
.PP
\fBParameters\fP
.RS 4
\fImethod\fP The request method string ('GET', 'PUT', 'POST', etc) that will be used in the HTTP request\&.
.RE
.PP
If this is not set on the target before it is opened, it will default to GET\&.
.PP
This attribute is ignored when opening the server side of an HTTP connection\&.
.PP
Setting this attribute may fail with
.IP "\(bu" 2
GLOBUS_XIO_ERROR_MEMORY
.IP "\(bu" 2
GLOBUS_XIO_ERROR_PARAMETER 
.PP

.SS "globus_result_t globus_xio_handle_cntl (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_END_OF_ENTITY\fP)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Indicate end-of-entity for an HTTP body\&.
.PP
HTTP clients and servers must call this command to indicate to the driver that the entity-body which is being sent is completed\&. Subsequent attempts to write data on the handle will fail\&.
.PP
This handle command MUST be called on the client side of an HTTP connection when the HTTP method is OPTIONS, POST, or PUT, or when the open attributes indicate that an entity will be sent\&. This handle command MUST be called on the server side of an HTTP request connection when the HTTP method was OPTIONS, GET, POST, or TRACE\&. 
.SS "globus_result_t globus_xio_handle_cntl (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HEADER\fP, const char * header_name, const char * header_value)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Set the value of a response HTTP header\&.
.PP
\fBParameters\fP
.RS 4
\fIheader_name\fP Name of the HTTP header to set\&. 
.br
\fIheader_value\fP Value of the HTTP header
.RE
.PP
Certain headers will cause changes in how the HTTP protocol will be handled\&. These include:
.IP "\(bu" 2
Transfer-Encoding: {identity|chunked} Override the default transfer encoding\&. If a server knows the exact length of the message body, or does not intend to support persistent connections, it may set this header to be 'identity'\&.
.br

.br
 If this is set to 'identity' and any of the following are true, then the connection will be closed after the end of the response is sent: 
.br

.br
.IP "  \(bu" 4
A Content-Length header is not present
.IP "  \(bu" 4
The HTTP version is set to 'HTTP/1\&.0'
.IP "  \(bu" 4
The Connection header is set to 'close' Attempts to set this to 'chunked' with an 'HTTP/1\&.0' client will fail with a GLOBUS_XIO_ERROR_HTTP_INVALID_HEADER error\&.
.PP

.IP "\(bu" 2
Content-Length: 1*Digit
.IP "  \(bu" 4
Provide a content length for the response message\&. If the 'chunked' transfer encoding is being used, then this header will be silently ignored by the HTTP driver\&.
.PP

.IP "\(bu" 2
Connection: close
.IP "  \(bu" 4
The HTTP connection will be closed after the end of the data response is written\&.
.PP

.PP
.PP
\fBReturns\fP
.RS 4
This handle control function can fail with
.IP "\(bu" 2
GLOBUS_XIO_ERROR_MEMORY
.IP "\(bu" 2
GLOBUS_XIO_ERROR_PARAMETER
.IP "\(bu" 2
GLOBUS_XIO_ERROR_HTTP_INVALID_HEADER 
.PP
.RE
.PP

.SS "globus_result_t globus_xio_handle_cntl (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_HTTP_VERSION\fP, \fBglobus_xio_http_version_t\fP version)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Set the response HTTP version\&.
.PP
\fBParameters\fP
.RS 4
\fIversion\fP The HTTP version to be used in the server response line\&.
.RE
.PP
If this cntl is not called by a server, then the default of GLOBUS_XIO_HTTP_VERSION_1_1 will be used, though no HTTP/1\&.1 features (chunking, persistent connections, etc) will be assumed if the client request was an HTTP/1\&.0 request\&. If this is called on the client-side of an HTTP connection, the handle control will fail with GLOBUS_XIO_ERROR_PARAMETER\&.
.PP
\fBReturns\fP
.RS 4
This handle control function can fail with
.IP "\(bu" 2
GLOBUS_XIO_ERROR_MEMORY
.IP "\(bu" 2
GLOBUS_XIO_ERROR_PARAMETER 
.PP
.RE
.PP

.SS "globus_result_t globus_xio_handle_cntl (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_REASON_PHRASE\fP, const char * reason)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Set the response reason phrase\&.
.PP
\fBParameters\fP
.RS 4
\fIreason\fP The value of the HTTP response string, as per RFC 2616\&.
.RE
.PP
If this cntl is not called by a server, then a default value based on the handle's response status code will be generated\&. If this is called on the client-side of an HTTP connection, the handle control will fail with a GLOBUS_XIO_ERROR_PARAMETER error\&.
.PP
\fBReturns\fP
.RS 4
This handle control function can fail with
.IP "\(bu" 2
GLOBUS_XIO_ERROR_MEMORY
.IP "\(bu" 2
GLOBUS_XIO_ERROR_PARAMETER 
.PP
.RE
.PP

.SS "globus_result_t globus_xio_handle_cntl (handle, driver, \fBGLOBUS_XIO_HTTP_HANDLE_SET_RESPONSE_STATUS_CODE\fP, int status)"
This is an overloaded member function, provided for convenience\&. It differs from the above function only in what argument(s) it accepts\&. Set the response status code\&.
.PP
\fBParameters\fP
.RS 4
\fIstatus\fP Value in the range 100-599 which will be used as the HTTP response code, as per RFC 2616\&.
.RE
.PP
If this cntl is not called by a server, then the default value of 200 ('Ok') will be used\&. If this is called on the client-side of an HTTP connection, the handle control will fail with a GLOBUS_XIO_ERROR_PARAMETER error\&.
.PP
\fBReturns\fP
.RS 4
This handle control function can fail with
.IP "\(bu" 2
GLOBUS_XIO_ERROR_PARAMETER 
.PP
.RE
.PP

.SH "Author"
.PP 
Generated automatically by Doxygen for globus_xio from the source code\&.