X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=http_functions.c;h=225019dc52f26924d85e94be508e59ab51d372ad;hb=10723276d6fc8e7a57f24038a2854342ebe3f23b;hp=f03398c4100ebfd242bbe48f34ec0d97c3455dba;hpb=98e0618077ab00672dd0e6e134d4722e033d827e;p=m6w6%2Fext-http diff --git a/http_functions.c b/http_functions.c index f03398c..225019d 100644 --- a/http_functions.c +++ b/http_functions.c @@ -38,7 +38,7 @@ /* {{{ proto string http_date([int timestamp]) * - * Compose a valid HTTP date regarding RFC 822/1123 + * Compose a valid HTTP date regarding RFC 1123 * looking like: "Wed, 22 Dec 2004 11:34:47 GMT" * * Accepts an optional unix timestamp as parameter. @@ -63,6 +63,44 @@ PHP_FUNCTION(http_date) /* {{{ proto string http_build_url(mixed url[, mixed parts[, int flags = HTTP_URL_REPLACE[, array &new_url]]]) * + * Build an URL. + * + * Expexts (part(s) of) an URL as first parameter in form of a string or assoziative array + * like parse_url() returns. Accepts an optional second parameter in the same way as the + * first argument. Accepts an optional third integer parameter, which is a bitmask of + * binary or'ed HTTP_URL_* constants. The optional fourth parameter will be filled + * with the results as associative array like parse_url() would return. + * + * The parts of the second URL will be merged into the first according to the flags argument. + * The following flags are recognized: + *
+ *	- HTTP_URL_REPLACE:        (default) set parts of the second url will replace the parts in the first
+ *	- HTTP_URL_JOIN_PATH:      the path of the second url will be merged into the one of the first
+ *	- HTTP_URL_JOIN_QUERY:     the two querystrings will be merged naivly; no replacements are done
+ *	- HTTP_URL_STRIP_USER:     the user part will not appear in the result
+ *	- HTTP_URL_STRIP_PASS:     the password part will not appear in the result
+ *	- HTTP_URL_STRIP_AUTH:     neither the user nor the password part will appear in the result
+ *	- HTTP_URL_STRIP_PORT:     no explicit port will be set in the result
+ *	- HTTP_URL_STRIP_PATH:     the path part will not appear in the result
+ *	- HTTP_URL_STRIP_QUERY:    no query string will be present in the result
+ *	- HTTP_URL_STRIP_FRAGMENT: no fragment will be present in the result
+ * 
+ * + * Example: + *
+ *  "ftp",
+ * 				"host"   => "ftp.example.com",
+ * 				"path"   => "files/current/",
+ * 				"query"  => "a=c"
+ * 			),
+ * 			HTTP_URL_STRIP_AUTH | HTTP_URL_JOIN_PATH | HTTP_URL_JOIN_QUERY | HTTP_URL_STRIP_FRAGMENT
+ * 		);
+ * ?>
+ * 
* Returns the new URL as string on success or FALSE on failure. */ PHP_FUNCTION(http_build_url) @@ -148,6 +186,13 @@ PHP_FUNCTION(http_build_url) /* {{{ proto string http_build_str(array query [, string prefix[, string arg_separator]]) * * Opponent to parse_str(). + * + * Expects an array as first argument which represents the parts of the query string to build. + * Accepts a string as optional second parameter containing a top-level prefix to use. + * The optional third parameter should specify an argument separator to use (by default the + * INI setting arg_separator.output will be used, or "&" if neither is set). + * + * Returns the built query as string on success or FALSE on failure. */ PHP_FUNCTION(http_build_str) { @@ -230,7 +275,7 @@ PHP_FUNCTION(http_build_str) * without qualifier are rated highest. The qualifier will be decreased by * 10% for partial matches (i.e. matching primary language). * - * Expects an array as parameter cotaining the supported languages as values. + * Expects an array as parameter containing the supported languages as values. * If the optional second parameter is supplied, it will be filled with an * array containing the negotiation results. * @@ -279,7 +324,7 @@ PHP_FUNCTION(http_negotiate_language) * Accept-Charset HTTP header. The qualifier is recognized and charsets * without qualifier are rated highest. * - * Expects an array as parameter cotaining the supported charsets as values. + * Expects an array as parameter containing the supported charsets as values. * If the optional second parameter is supplied, it will be filled with an * array containing the negotiation results. * @@ -331,7 +376,7 @@ PHP_FUNCTION(http_negotiate_charset) * Accept HTTP header. The qualifier is recognized and content types * without qualifier are rated highest. * - * Expects an array as parameter cotaining the supported content types as values. + * Expects an array as parameter containing the supported content types as values. * If the optional second parameter is supplied, it will be filled with an * array containing the negotiation results. * @@ -442,7 +487,7 @@ PHP_FUNCTION(http_send_content_type) * if the data actually sent came from a file or something similar, that should * be "saved" by the client/user (i.e. by browsers "Save as..." popup window). * - * Expects a string parameter specifying the file name the "Save as..." dialogue + * Expects a string parameter specifying the file name the "Save as..." dialog * should display. Optionally accepts a bool parameter, which, if set to true * and the user agent knows how to handle the content type, will probably not * cause the popup window to be shown. @@ -505,7 +550,7 @@ PHP_FUNCTION(http_match_modified) * accepts a bool parameter, which, if set to true, will check the header * usually used to validate HTTP ranges. * - * Retuns TRUE if ETag matches or the header contained the asterisk ("*"), + * Returns TRUE if ETag matches or the header contained the asterisk ("*"), * else FALSE. */ PHP_FUNCTION(http_match_etag) @@ -581,7 +626,7 @@ PHP_FUNCTION(http_cache_last_modified) /* {{{ proto bool http_cache_etag([string etag]) * * Attempts to cache the sent entity by its ETag, either supplied or generated - * by the hash algorythm specified by the INI setting "http.etag_mode". + * by the hash algorithm specified by the INI setting "http.etag_mode". * * If the clients "If-None-Match" header matches the supplied/calculated * ETag, the body is considered cached on the clients side and @@ -610,7 +655,7 @@ PHP_FUNCTION(http_cache_etag) /* {{{ proto string ob_etaghandler(string data, int mode) * * For use with ob_start(). Output buffer handler generating an ETag with - * the hash algorythm specified with the INI setting "http.etag_mode". + * the hash algorithm specified with the INI setting "http.etag_mode". */ PHP_FUNCTION(ob_etaghandler) { @@ -657,8 +702,8 @@ PHP_FUNCTION(http_throttle) return; } - HTTP_G(send).throttle_delay = interval; - HTTP_G(send).buffer_size = chunk_size; + HTTP_G->send.throttle_delay = interval; + HTTP_G->send.buffer_size = chunk_size; } /* }}} */ @@ -683,7 +728,7 @@ PHP_FUNCTION(http_throttle) * for which redirect response code to use in which situation. * * To be RFC compliant, "Redirecting to URL." will be displayed, - * if the client doesn't redirect immediatly, and the request method was + * if the client doesn't redirect immediately, and the request method was * another one than HEAD. * * Returns FALSE on failure, or *exits* on success. @@ -794,7 +839,7 @@ PHP_FUNCTION(http_redirect) * * Sends raw data with support for (multiple) range requests. * - * Retursn TRUE on success, or FALSE on failure. + * Returns TRUE on success, or FALSE on failure. */ PHP_FUNCTION(http_send_data) { @@ -837,7 +882,7 @@ PHP_FUNCTION(http_send_file) * * Sends an already opened stream with support for (multiple) range requests. * - * Expects a resource parameter referncing the stream to read from. + * Expects a resource parameter referencing the stream to read from. * * Returns TRUE on success, or FALSE on failure. */ @@ -888,7 +933,7 @@ PHP_FUNCTION(http_chunked_decode) * Expects a string parameter containing a single HTTP message or * several consecutive HTTP messages. * - * Returns an hierachical object structure of the parsed messages. + * Returns an hierarchical object structure of the parsed messages. * * Example: *
@@ -1154,7 +1199,6 @@ PHP_FUNCTION(http_match_request_header)
  *  - httpauth:         string, http credentials in "user:pass" format
  *  - httpauthtype:     int, HTTP_AUTH_BASIC, DIGEST and/or NTLM
  *  - compress:         bool, whether to allow gzip/deflate content encoding
- *                      (defaults to true)
  *  - port:             int, use another port as specified in the url
  *  - referer:          string, the referer to send
  *  - useragent:        string, the user agent to send
@@ -1163,19 +1207,38 @@ PHP_FUNCTION(http_match_request_header)
  *                      like array("header" => "value")
  *  - cookies:          array, list of cookies as associative array
  *                      like array("cookie" => "value")
+ *  - encodecookies:    bool, whether to urlencode the cookies (default: true)
+ *  - resetcookies:     bool, wheter to reset the cookies
  *  - cookiestore:      string, path to a file where cookies are/will be stored
  *  - resume:           int, byte offset to start the download from;
  *                      if the server supports ranges
  *  - maxfilesize:      int, maximum file size that should be downloaded;
  *                      has no effect, if the size of the requested entity is not known
  *  - lastmodified:     int, timestamp for If-(Un)Modified-Since header
+ *  - etag:             string, quoted etag for If-(None-)Match header
  *  - timeout:          int, seconds the request may take
  *  - connecttimeout:   int, seconds the connect may take
  *  - onprogress:       mixed, progress callback
+ *  - ssl:              array, with the following options:
+ *                      cert:        string, path to certificate
+ *                      certtype:    string, type of certificate
+ *                      certpasswd:  string, password for certificate
+ *                      key:         string, path to key
+ *                      keytype:     string, type of key
+ *                      keypasswd:   string, pasword for key
+ *                      engine:      string, ssl engine to use
+ *                      version:     int, ssl version to use
+ *                      verifypeer:  bool, whether to verify the peer
+ *                      verifyhost:  bool whether to verify the host
+ *                      cipher_list: string, list of allowed ciphers
+ *                      cainfo:      string
+ *                      capath:      string
+ *                      random_file: string
+ *                      egdsocket:   string
  * 
* * The optional third parameter will be filled with some additional information - * in form af an associative array, if supplied, like the following example: + * in form of an associative array, if supplied, like the following example: *
  *