Annotation of embedaddon/libpdel/http/http_response.3, revision 1.1.1.1

1.1       misho       1: .\" Copyright (c) 2001-2002 Packet Design, LLC.
                      2: .\" All rights reserved.
                      3: .\" 
                      4: .\" Subject to the following obligations and disclaimer of warranty,
                      5: .\" use and redistribution of this software, in source or object code
                      6: .\" forms, with or without modifications are expressly permitted by
                      7: .\" Packet Design; provided, however, that:
                      8: .\" 
                      9: .\"    (i)  Any and all reproductions of the source or object code
                     10: .\"         must include the copyright notice above and the following
                     11: .\"         disclaimer of warranties; and
                     12: .\"    (ii) No rights are granted, in any manner or form, to use
                     13: .\"         Packet Design trademarks, including the mark "PACKET DESIGN"
                     14: .\"         on advertising, endorsements, or otherwise except as such
                     15: .\"         appears in the above copyright notice or in the software.
                     16: .\" 
                     17: .\" THIS SOFTWARE IS BEING PROVIDED BY PACKET DESIGN "AS IS", AND
                     18: .\" TO THE MAXIMUM EXTENT PERMITTED BY LAW, PACKET DESIGN MAKES NO
                     19: .\" REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING
                     20: .\" THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY AND ALL IMPLIED
                     21: .\" WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
                     22: .\" OR NON-INFRINGEMENT.  PACKET DESIGN DOES NOT WARRANT, GUARANTEE,
                     23: .\" OR MAKE ANY REPRESENTATIONS REGARDING THE USE OF, OR THE RESULTS
                     24: .\" OF THE USE OF THIS SOFTWARE IN TERMS OF ITS CORRECTNESS, ACCURACY,
                     25: .\" RELIABILITY OR OTHERWISE.  IN NO EVENT SHALL PACKET DESIGN BE
                     26: .\" LIABLE FOR ANY DAMAGES RESULTING FROM OR ARISING OUT OF ANY USE
                     27: .\" OF THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY DIRECT,
                     28: .\" INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, PUNITIVE, OR CONSEQUENTIAL
                     29: .\" DAMAGES, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, LOSS OF
                     30: .\" USE, DATA OR PROFITS, HOWEVER CAUSED AND UNDER ANY THEORY OF
                     31: .\" LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
                     32: .\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
                     33: .\" THE USE OF THIS SOFTWARE, EVEN IF PACKET DESIGN IS ADVISED OF
                     34: .\" THE POSSIBILITY OF SUCH DAMAGE.
                     35: .\"
                     36: .\" Author: Archie Cobbs <archie@freebsd.org>
                     37: .\"
                     38: .\" $Id: http_response.3,v 1.14 2004/06/02 17:24:37 archie Exp $
                     39: .\"
                     40: .Dd April 22, 2002
                     41: .Dt HTTP_RESPONSE 3
                     42: .Os
                     43: .Sh NAME
                     44: .Nm http_response
                     45: .Nd HTTP response object
                     46: .Sh LIBRARY
                     47: PDEL Library (libpdel, \-lpdel)
                     48: .Sh SYNOPSIS
                     49: .In sys/types.h
                     50: .In stdio.h
                     51: .In netinet/in.h
                     52: .In openssl/ssl.h
                     53: .In pdel/http/http_defs.h
                     54: .In pdel/http/http_server.h
                     55: .\"
                     56: .Ss Accessors
                     57: .\"
                     58: .Ft "int"
                     59: .Fn http_response_get_code "struct http_response *resp"
                     60: .Ft "struct in_addr"
                     61: .Fn http_response_get_remote_ip "struct http_response *resp"
                     62: .Ft "u_int16_t"
                     63: .Fn http_response_get_remote_port "struct http_response *resp"
                     64: .Ft "SSL_CTX *"
                     65: .Fn http_response_get_ssl "struct http_response *resp"
                     66: .\"
                     67: .Ss "HTTP Headers"
                     68: .\"
                     69: .Ft "int"
                     70: .Fn http_response_num_headers "struct http_response *req"
                     71: .Ft "const char *"
                     72: .Fn http_response_get_header "struct http_response *resp" "const char *name"
                     73: .Ft "int"
                     74: .Fn http_response_get_header_by_index "struct http_response *resp" "u_int index" "const char **namep" "const char **valuep"
                     75: .Ft "int"
                     76: .Fn http_response_set_header "struct http_response *resp" "int append" "const char *name" "const char *valfmt" "..."
                     77: .Ft "int"
                     78: .Fn http_response_remove_header "struct http_response *resp" "const char *name"
                     79: .Ft "int"
                     80: .Fn http_response_send_headers "struct http_response *resp" "int unbuffer"
                     81: .\"
                     82: .Ss "HTTP Body"
                     83: .\"
                     84: .Ft "FILE *"
                     85: .Fn http_response_get_input "struct http_response *resp"
                     86: .Ft "FILE *"
                     87: .Fn http_response_get_output "struct http_response *resp" "int buffer"
                     88: .\"
                     89: .Ss "Canned Responses"
                     90: .\"
                     91: .Ft "void"
                     92: .Fn http_response_send_redirect "struct http_response *resp" "const char *url"
                     93: .Ft "void"
                     94: .Fn http_response_send_basic_auth "struct http_response *resp" "const char *realm"
                     95: .Ft "void"
                     96: .Fn http_response_send_error "struct http_response *resp" "int code" "const char *fmt" "..."
                     97: .Ft "void"
                     98: .Fn http_response_send_errno_error "struct http_response *resp"
                     99: .\"
                    100: .Ss Miscellaneous
                    101: .\"
                    102: .Ft "void"
                    103: .Fn http_response_guess_mime "const char *path" "const char **ctype" "const char **cencs" "int maxenc"
                    104: .Ft "const char *"
                    105: .Fn http_response_status_msg "int code"
                    106: .Ft "int"
                    107: .Fn http_response_no_body "int code"
                    108: .Ft "int"
                    109: .Fn http_response_get_raw_socket "struct http_response *resp"
                    110: .\"
                    111: .Sh DESCRIPTION
                    112: .\"
                    113: The
                    114: .Nm http_response
                    115: object is used by the PDEL HTTP library to represent an HTTP response.
                    116: An HTTP response may be associated with an HTTP server (the response is
                    117: generated locally) or an HTTP client (the response is generated remotely).
                    118: Some of the functions and values defined below only make sense in one
                    119: of these cases.
                    120: .Pp
                    121: .Nm http_response
                    122: objects are not created directly; rather, they are obtained from another
                    123: object which is associated with the HTTP connection.
                    124: They are freed automatically (and become invalid) when the corresponding
                    125: HTTP connection object is closed.
                    126: .\"
                    127: .Ss Accessors
                    128: .\"
                    129: .Fn http_response_get_code
                    130: returns the HTTP status code from the response, e.g., 200 for "OK".
                    131: Status codes are defined in
                    132: .Li "<pdel/http/http_defs.h>" ,
                    133: which is included by
                    134: .Li "<pdel/http/http_server.h>" .
                    135: .Pp
                    136: .Fn http_response_get_remote_ip
                    137: returns the IP address of the remote side.
                    138: .Pp
                    139: .Fn http_response_get_remote_port
                    140: returns the TCP port of the remote side.
                    141: .Pp
                    142: .Fn http_response_get_ssl
                    143: returns the SSL context for the HTTP connection, or
                    144: .Dv NULL
                    145: if the connection is not over SSL.
                    146: .\"
                    147: .Ss "HTTP Headers"
                    148: .\"
                    149: .Fn http_response_get_header
                    150: returns the value of the named header, or
                    151: .Dv NULL
                    152: if the header is not defined for the response.
                    153: HTTP header names are case-insensitive.
                    154: .Pp
                    155: .Fn http_response_num_headers
                    156: returns the number of headers in the response.
                    157: .Pp
                    158: .Fn http_response_get_header_by_index
                    159: points
                    160: .Fa "*namep"
                    161: at the name and
                    162: .Fa "*valuep"
                    163: at the value of the header with index
                    164: .Fa index ,
                    165: which must be less than the value returned by
                    166: .Fn http_response_num_headers .
                    167: .Pp
                    168: .Fn http_response_set_header
                    169: formats and sets a header value.
                    170: If
                    171: .Fa append
                    172: is non-zero, the value is appended to any existing value
                    173: (after adding a ",\ " separator) rather than replacing it.
                    174: As a special case, setting the "Set-Cookie" header does not
                    175: replace existing instances, it just adds a new instance.
                    176: When the response headers are sent, all instances of "Set-Cookie" are sent.
                    177: .Pp
                    178: .Fn http_response_remove_header
                    179: removes a header from the response.
                    180: .Pp
                    181: .Fn http_response_send_headers
                    182: causes the server response headers to be sent to the client if they
                    183: haven't already been sent.
                    184: Setting
                    185: .Fa unbuffer
                    186: to non-zero causes the output to be unbuffered.
                    187: It has the same affect as setting
                    188: .Fa buffer
                    189: to zero when calling
                    190: .Fn http_response_get_output
                    191: (see below).
                    192: .\"
                    193: .Ss "HTTP Body"
                    194: .\"
                    195: .Fn http_response_get_input
                    196: returns the body of the response as an input stream.
                    197: The local side must be the client for this HTTP connection.
                    198: .Pp
                    199: .Fn http_response_get_output
                    200: returns an output stream that writes into the body of the response.
                    201: The local side must be the server for this HTTP connection.
                    202: .Fa buffer
                    203: determines whether the entire output should be buffered before sending, or
                    204: should writes to the stream translate immediately into writes to the server.
                    205: The latter option will force the headers to be sent (if they haven't been
                    206: sent already) when the first byte is written to the stream.
                    207: Setting
                    208: .Fa buffer
                    209: to zero is also incompatible with keep-alive, unless the user code manually
                    210: sets the "Content-Length" header (in which case it takes responsibility
                    211: for writing the correct number of bytes).
                    212: If
                    213: .Fa buffer
                    214: is non-zero, the output will be buffered entirely in memory until the output
                    215: stream is closed, at which point "Content-Length" is computed automatically.
                    216: .Pp
                    217: Certain HTTP responses (e.g., "304 Not Modified") do not have an associated
                    218: response body (see
                    219: .Fn http_response_no_body
                    220: below); for these responses, the output stream returned by
                    221: .Fn http_response_get_output
                    222: will discard all data written to it.
                    223: .\"
                    224: .Ss "Canned Responses"
                    225: .\"
                    226: .Fn http_response_send_redirect
                    227: sends an HTTP redirect (301) to the client.
                    228: .Fa url
                    229: is the URL to which the client should be redirected.
                    230: .Pp
                    231: .Fn http_response_send_basic_auth
                    232: sends an "Unauthorized" repsonse (401) to the client, causing browsers
                    233: to pop up a login window.
                    234: Only "Basic" authentication is supported.
                    235: The
                    236: .Fa realm
                    237: is the authentication realm (which is usually visible in the popup window).
                    238: .Pp
                    239: .Fn http_response_send_error
                    240: formats and sends an error response to the client with the HTTP status code
                    241: .Fa code .
                    242: For status codes that have response bodies, a very simple HTML page
                    243: is cobbled together and sent as well.
                    244: .Fa fmt
                    245: may be
                    246: .Dv NULL
                    247: to use the generic error message that corresponds to
                    248: .Fa code ;
                    249: otherwise, the error string is formatted as with
                    250: .Xr printf 3 .
                    251: .Pp
                    252: .Fn http_response_send_errno_error
                    253: attempts to generate an appropriate error response based on the value of
                    254: .Va errno .
                    255: .\"
                    256: .Ss Miscellaneous
                    257: .\"
                    258: .Fn http_response_guess_mime
                    259: tries to guess the MIME "Content-Type" and "Content-Encoding" of the file 
                    260: .Fa path .
                    261: The content type is returned in
                    262: .Fa "*ctype" .
                    263: If it can't be determined, "text/plain; charset=iso-8859-1" is returned.
                    264: .Pp
                    265: The content encoding is really a list of encodings.
                    266: For example, "foo.uu.gz" would be detected as having encoding
                    267: "x-uuencode" followed by "gzip".
                    268: The
                    269: .Fa "cencs"
                    270: argument should point to an array of
                    271: .Li "char *"
                    272: having length
                    273: .Fa maxencs .
                    274: This array will be filled in and any extra entries set to
                    275: .Dv NULL .
                    276: If
                    277: .Fa "cencs"
                    278: is
                    279: .Dv NULL ,
                    280: no attempt is made to determine content encoding.
                    281: .Pp
                    282: .Fn http_response_status_msg
                    283: returns an ASCII string corresponding to the HTTP response code
                    284: .Fa code .
                    285: .Pp
                    286: .Fn http_response_no_body
                    287: returns 1 if a response with HTTP response code
                    288: .Fa code
                    289: should not have a response body, otherwise zero.
                    290: .Pp
                    291: .Fn http_response_get_raw_socket
                    292: returns the underlying file descriptor for the HTTP connection.
                    293: This is a huge layering violation fraught with danger.
                    294: This function will fail for SSL connections.
                    295: The returned file descriptor should not be closed.
                    296: .Sh RETURN VALUES
                    297: All of the above routines that can return an error return
                    298: .Dv NULL
                    299: or -1 to indicate this and set
                    300: .Va errno
                    301: to an appropriate value.
                    302: Success is indicated by a normal return value or zero.
                    303: .Sh SEE ALSO
                    304: .Xr http_client 3 ,
                    305: .Xr http_mime 3 ,
                    306: .Xr http_request 3 ,
                    307: .Xr http_server 3 ,
                    308: .Xr http_servlet 3 ,
                    309: .Xr libpdel 3
                    310: .Rs
                    311: .%A R. Fielding
                    312: .%A J. Gettys
                    313: .%A J. Mogul
                    314: .%A H. Frystyk
                    315: .%A L. Masinter
                    316: .%A P. Leach
                    317: .%A T. Berners-Lee
                    318: .%T "Hypertext Transfer Protocol -- HTTP/1.1"
                    319: .%O RFC 2616
                    320: .Re
                    321: .Sh HISTORY
                    322: The PDEL library was developed at Packet Design, LLC.
                    323: .Dv "http://www.packetdesign.com/"
                    324: .Sh AUTHORS
                    325: .An Archie Cobbs Aq archie@freebsd.org
                    326: .Sh BUGS
                    327: There are not as many
                    328: .Nm http_response
                    329: methods as there are
                    330: .Nm http_request
                    331: methods.
                    332: This reflects a bias of the library towards implementing servers
                    333: rather than clients.
                    334: More support for the client side should be added.

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>