| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 | '\" t.\"     Title: ne_request_create.\"    Author: .\" Generator: DocBook XSL Stylesheets vsnapshot <http://docbook.sf.net/>.\"      Date: 21 January 2023.\"    Manual: neon API reference.\"    Source: neon 0.32.5.\"  Language: English.\".TH "NE_REQUEST_CREATE" "3" "21 January 2023" "neon 0.32.5" "neon API reference".\" -----------------------------------------------------------------.\" * Define some portability stuff.\" -----------------------------------------------------------------.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~.\" http://bugs.debian.org/507673.\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~.ie \n(.g .ds Aq \(aq.el       .ds Aq '.\" -----------------------------------------------------------------.\" * set default formatting.\" -----------------------------------------------------------------.\" disable hyphenation.nh.\" disable justification (adjust text to left margin only).ad l.\" -----------------------------------------------------------------.\" * MAIN CONTENT STARTS HERE *.\" -----------------------------------------------------------------.SH "NAME"ne_request_create, ne_request_dispatch, ne_request_destroy \- low\-level HTTP request handling.SH "SYNOPSIS".sp.ft B.nf#include <ne_request\&.h>.fi.ft.HP \w'ne_request\ *ne_request_create('u.BI "ne_request *ne_request_create(ne_session\ *" "session" ", const\ char\ *" "method" ", const\ char\ *" "path" ");".HP \w'int\ ne_request_dispatch('u.BI "int ne_request_dispatch(ne_request\ *" "req" ");".HP \w'void\ ne_request_destroy('u.BI "void ne_request_destroy(ne_request\ *" "req" ");".SH "DESCRIPTION".PPThe\fBne_request\fRobject represents an HTTP request and the associated response\&. The\fBne_request_create\fRfunction creates a new request object for the given\fIsession\fR\&. The target resource for the request is identified by the\fIpath\fR, and the method to be performed on that resource via the\fImethod\fRparameter\&..PPThe\fIpath\fRstring used must conform to theabs_pathdefinition given in RFC2396, with an optional "?query" part, and must be URI\-escaped by the caller (for instance, using\fBne_path_escape\fR)\&. If the string comes from an untrusted source, failure to perform URI\-escaping results in a security vulnerability\&..PPTo dispatch a request, and process the response, the\fBne_request_dispatch\fRfunction can be used\&. An alternative is to use the (more complex, but more flexible) combination of the\fBne_begin_request\fR,\fBne_end_request\fR, and\fBne_read_response_block\fRfunctions; see\fBne_begin_request\fR\&..PPTo add extra headers in the request, the functionsne_add_request_headerandne_print_request_headercan be used\&. To include a message body with the request, one of the functions\fBne_set_request_body_buffer\fR,\fBne_set_request_body_fd\fR, or\fBne_set_request_body_provider\fRcan be used\&..PPThe return value of\fBne_request_dispatch\fRindicates merely whether the request was sent and the response read successfully\&. To discover the result of the operation,ne_get_status, along with any processing of the response headers and message body\&..PPA request can only be dispatched once: calling\fBne_request_dispatch\fRmore than once on a single\fBne_request\fRobject produces undefined behaviour\&. Once all processing associated with the request object is complete, use the\fBne_request_destroy\fRfunction to destroy the resources associated with it\&. Any subsequent use of the request object produces undefined behaviour\&..PPFor a request with a non\-idempotent method such asPOST, theNE_REQFLAG_IDEMPOTENTflag should be disabled; seene_set_request_flag\&..SH "RETURN VALUE".PPThe\fBne_request_create\fRfunction returns a pointer to a request object (and neverNULL)\&..PPThe\fBne_request_dispatch\fRfunction returns zero if the request was dispatched successfully, and a non\-zero error code otherwise\&..SH "ERRORS".PP\fBNE_ERROR\fR.RS 4Request failed (see session error string).RE.PP\fBNE_LOOKUP\fR.RS 4The DNS lookup for the server (or proxy server) failed\&..RE.PP\fBNE_AUTH\fR.RS 4Authentication failed on the server\&..RE.PP\fBNE_PROXYAUTH\fR.RS 4Authentication failed on the proxy server\&..RE.PP\fBNE_CONNECT\fR.RS 4A connection to the server could not be established\&..RE.PP\fBNE_TIMEOUT\fR.RS 4A timeout occurred while waiting for the server to respond\&..RE.SH "EXAMPLE".PPAn example of applying aMKCOLoperation to the resource at the locationhttp://www\&.example\&.com/foo/bar/:.sp.if n \{\.RS 4.\}.nfne_session *sess = ne_session_create("http", "www\&.example\&.com", 80);ne_request *req = ne_request_create(sess, "MKCOL", "/foo/bar/");if (ne_request_dispatch(req)) {   printf("Request failed: %s\en", ne_get_error(sess));}ne_request_destroy(req);.fi.if n \{\.RE.\}.SH "SEE ALSO".PPne_get_error,ne_set_error,ne_get_status,ne_add_request_header,ne_set_request_body_buffer,ne_set_request_flag\&..SH "AUTHOR".PP\fBJoe Orton\fR.RS 4Author..RE.SH "COPYRIGHT".br
 |