+
+PHP_METHOD(HttpMessage, getType)
+
+{
+
+ getObject(http_message_object, obj);
+
+
+
+ NO_ARGS;
+
+
+
+ RETURN_LONG(obj->message->type);
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto void HttpMessage::setType(long type)
+
+ *
+
+ * Set Message Type. (HTTP_MSG_NONE|HTTP_MSG_REQUEST|HTTP_MSG_RESPONSE)
+
+ */
+
+PHP_METHOD(HttpMessage, setType)
+
+{
+
+ long type;
+
+ getObject(http_message_object, obj);
+
+
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &type)) {
+
+ return;
+
+ }
+
+ http_message_set_type(obj->message, type);
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto long HttpMessage::getResponseCode()
+
+ *
+
+ * Get the Response Code of the Message.
+
+ */
+
+PHP_METHOD(HttpMessage, getResponseCode)
+
+{
+
+ getObject(http_message_object, obj);
+
+
+
+ NO_ARGS;
+
+
+
+ if (!HTTP_MSG_TYPE(RESPONSE, obj->message)) {
+
+ http_error(E_NOTICE, HTTP_E_MSG, "HttpMessage is not of type HTTP_MSG_RESPONSE");
+
+ RETURN_NULL();
+
+ }
+
+
+
+ RETURN_LONG(obj->message->info.response.code);
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto bool HttpMessage::setResponseCode(long code)
+
+ *
+
+ * Set the response code of an HTTP Response Message.
+
+ * Returns false if the Message is not of type HTTP_MSG_RESPONSE,
+
+ * or if the response code is out of range (100-510).
+
+ */
+
+PHP_METHOD(HttpMessage, setResponseCode)
+
+{
+
+ long code;
+
+ getObject(http_message_object, obj);
+
+
+
+ if (obj->message->type != HTTP_MSG_RESPONSE) {
+
+ http_error(E_WARNING, HTTP_E_MSG, "HttpMessage is not of type HTTP_MSG_RESPONSE");
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &code)) {
+
+ RETURN_FALSE;
+
+ }
+
+ if (code < 100 || code > 510) {
+
+ http_error_ex(E_WARNING, HTTP_E_PARAM, "Invalid response code (100-510): %ld", code);
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ obj->message->info.response.code = code;
+
+ RETURN_TRUE;
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto string HttpMessage::getRequestMethod()
+
+ *
+
+ * Get the Request Method of the Message.
+
+ * Returns false if the Message is not of type HTTP_MSG_REQUEST.
+
+ */
+
+PHP_METHOD(HttpMessage, getRequestMethod)
+
+{
+
+ getObject(http_message_object, obj);
+
+
+
+ NO_ARGS;
+
+
+
+ if (obj->message->type != HTTP_MSG_REQUEST) {
+
+ http_error(E_NOTICE, HTTP_E_MSG, "HttpMessage is not of type HTTP_MSG_REQUEST");
+
+ RETURN_NULL();
+
+ }
+
+
+
+ RETURN_STRING(obj->message->info.request.method, 1);
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto bool HttpMessage::setRequestMethod(string method)
+
+ *
+
+ * Set the Request Method of the HTTP Message.
+
+ * Returns false if the Message is not of type HTTP_MSG_REQUEST.
+
+ */
+
+PHP_METHOD(HttpMessage, setRequestMethod)
+
+{
+
+ char *method;
+
+ int method_len;
+
+ getObject(http_message_object, obj);
+
+
+
+ if (obj->message->type != HTTP_MSG_REQUEST) {
+
+ http_error(E_WARNING, HTTP_E_MSG, "HttpMessage is not of type HTTP_MSG_REQUEST");
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &method, &method_len)) {
+
+ RETURN_FALSE;
+
+ }
+
+ if (method_len < 1) {
+
+ http_error(E_WARNING, HTTP_E_PARAM, "Cannot set HttpMessage::requestMethod to an empty string");
+
+ RETURN_FALSE;
+
+ }
+
+ if (SUCCESS != http_check_method(method)) {
+
+ http_error_ex(E_WARNING, HTTP_E_PARAM, "Unkown request method: %s", method);
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ if (obj->message->info.request.method) {
+
+ efree(obj->message->info.request.method);
+
+ }
+
+ obj->message->info.request.method = estrndup(method, method_len);
+
+ RETURN_TRUE;
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto string HttpMessage::getRequestUri()
+
+ *
+
+ * Get the Request URI of the Message.
+
+ */
+
+PHP_METHOD(HttpMessage, getRequestUri)
+
+{
+
+ zval *uri;
+
+ getObject(http_message_object, obj);
+
+
+
+ NO_ARGS;
+
+
+
+ if (obj->message->type != HTTP_MSG_REQUEST) {
+
+ http_error(E_WARNING, HTTP_E_MSG, "HttpMessage is not of type HTTP_MSG_REQUEST");
+
+ RETURN_NULL();
+
+ }
+
+
+
+ RETURN_STRING(obj->message->info.request.URI, 1);
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto bool HttpMessage::setRequestUri(string URI)
+
+ *
+
+ * Set the Request URI of the HTTP Message.
+
+ * Returns false if the Message is not of type HTTP_MSG_REQUEST,
+
+ * or if paramtere URI was empty.
+
+ */
+
+PHP_METHOD(HttpMessage, setRequestUri)
+
+{
+
+ char *URI;
+
+ int URIlen;
+
+ getObject(http_message_object, obj);
+
+
+
+ if (obj->message->type != HTTP_MSG_REQUEST) {
+
+ http_error(E_WARNING, HTTP_E_MSG, "HttpMessage is not of type HTTP_MSG_REQUEST");
+
+ RETURN_FALSE;
+
+ }
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &URI, &URIlen)) {
+
+ RETURN_FALSE;
+
+ }
+
+ if (URIlen < 1) {
+
+ http_error(E_WARNING, HTTP_E_PARAM, "Cannot set HttpMessage::requestUri to an empty string");
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ if (obj->message->info.request.URI) {
+
+ efree(obj->message->info.request.URI);
+
+ }
+
+ obj->message->info.request.URI = estrndup(URI, URIlen);
+
+ RETURN_TRUE;
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto string HttpMessage::getHttpVersion()
+
+ *
+
+ * Get the HTTP Protocol Version of the Message.
+
+ */
+
+PHP_METHOD(HttpMessage, getHttpVersion)
+
+{
+
+ char ver[4] = {0};
+
+ float version;
+
+ getObject(http_message_object, obj);
+
+
+
+ NO_ARGS;
+
+
+
+ switch (obj->message->type)
+
+ {
+
+ case HTTP_MSG_RESPONSE:
+
+ version = obj->message->info.response.http_version;
+
+ break;
+
+
+
+ case HTTP_MSG_REQUEST:
+
+ version = obj->message->info.request.http_version;
+
+ break;
+
+
+
+ case HTTP_MSG_NONE:
+
+ default:
+
+ RETURN_NULL();
+
+ }
+
+ sprintf(ver, "%1.1f", version);
+
+ RETURN_STRINGL(ver, 3, 1);
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto bool HttpMessage::setHttpVersion(string version)
+
+ *
+
+ * Set the HTTP Protocol version of the Message.
+
+ * Returns false if version is invalid (1.0 and 1.1).
+
+ */
+
+PHP_METHOD(HttpMessage, setHttpVersion)
+
+{
+
+ char v[4];
+
+ zval *zv, *version;
+
+ getObject(http_message_object, obj);
+
+
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z/", &zv)) {
+
+ return;
+
+ }
+
+
+
+ if (obj->message->type == HTTP_MSG_NONE) {
+
+ http_error(E_WARNING, HTTP_E_MSG, "Message is neither of type HTTP_MSG_RESPONSE nor HTTP_MSG_REQUEST");
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ convert_to_double_ex(&zv);
+
+ sprintf(v, "%1.1f", Z_DVAL_P(zv));
+
+ if (strcmp(v, "1.0") && strcmp(v, "1.1")) {
+
+ http_error_ex(E_WARNING, HTTP_E_PARAM, "Invalid HTTP protocol version (1.0 or 1.1): %s", v);
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ if (obj->message->type == HTTP_MSG_RESPONSE) {
+
+ obj->message->info.response.http_version = (float) Z_DVAL_P(zv);
+
+ } else {
+
+ obj->message->info.request.http_version = (float) Z_DVAL_P(zv);
+
+ }
+
+ RETURN_TRUE;
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto HttpMessage HttpMessage::getParentMessage()
+
+ *
+
+ * Get parent Message.
+
+ */
+
+PHP_METHOD(HttpMessage, getParentMessage)
+
+{
+
+ getObject(http_message_object, obj);
+
+
+
+ NO_ARGS;
+
+
+
+ if (obj->message->parent) {
+
+ RETVAL_OBJVAL(obj->parent);
+
+ } else {
+
+ RETVAL_NULL();
+
+ }
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto bool HttpMessage::send()
+
+ *
+
+ * Send the Message according to its type as Response or Request.
+
+ */
+
+PHP_METHOD(HttpMessage, send)
+
+{
+
+ getObject(http_message_object, obj);
+
+
+
+ NO_ARGS;
+
+
+
+ RETURN_SUCCESS(http_message_send(obj->message));
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto string HttpMessage::toString([bool include_parent = true])
+
+ *
+
+ * Get the string representation of the Message.
+
+ */
+
+PHP_METHOD(HttpMessage, toString)
+
+{
+
+ char *string;
+
+ size_t length;
+
+ zend_bool include_parent = 1;
+
+ getObject(http_message_object, obj);
+
+
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|b", &include_parent)) {
+
+ RETURN_FALSE;
+
+ }
+
+
+
+ if (include_parent) {
+
+ http_message_serialize(obj->message, &string, &length);
+
+ } else {
+
+ http_message_tostring(obj->message, &string, &length);
+
+ }
+
+ RETURN_STRINGL(string, length, 0);
+
+}
+
+/* }}} */
+
+
+
+/* }}} */
+
+
+
+#ifdef HTTP_HAVE_CURL
+
+/* {{{ HttpRequest */
+
+
+
+/* {{{ proto void HttpRequest::__construct([string url[, long request_method = HTTP_GET]])
+
+ *
+
+ * Instantiate a new HttpRequest object which can be used to issue HEAD, GET
+
+ * and POST (including posting files) HTTP requests.
+
+ */
+
+PHP_METHOD(HttpRequest, __construct)
+
+{
+
+ char *URL = NULL;
+
+ int URL_len;
+
+ long meth = -1;
+
+ getObject(http_request_object, obj);
+
+
+
+ SET_EH_THROW_HTTP();
+
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|sl", &URL, &URL_len, &meth)) {
+
+ INIT_PARR(obj, options);
+
+ INIT_PARR(obj, responseInfo);
+
+ INIT_PARR(obj, responseData);
+
+ INIT_PARR(obj, postData);
+
+ INIT_PARR(obj, postFiles);
+
+
+
+ if (URL) {
+
+ UPD_PROP(obj, string, url, URL);
+
+ }
+
+ if (meth > -1) {
+
+ UPD_PROP(obj, long, method, meth);
+
+ }
+
+ }
+
+ SET_EH_NORMAL();
+
+}
+
+/* }}} */
+
+
+
+/* {{{ proto void HttpRequest::__destruct()
+
+ *
+
+ * Destroys the HttpRequest object.
+
+ */
+
+PHP_METHOD(HttpRequest, __destruct)
+