- /* new line */
- if (strncmp(e_ptr, HTTP_CRLF, 2)) {
- php_error_docref(NULL TSRMLS_CC, E_WARNING,
- "Invalid character (expected 0x0D 0x0A; got: %x %x)",
- *e_ptr, *(e_ptr + 1));
- efree(*decoded);
- return FAILURE;
- }
+/* {{{ STATUS http_exit(int, char*, char*) */
+STATUS _http_exit_ex(int status, char *header, char *body, zend_bool send_header TSRMLS_DC)
+{
+ if ( (send_header && (SUCCESS != http_send_status_header(status, header))) ||
+ (!send_header && status && (SUCCESS != http_send_status(status)))) {
+ http_error_ex(HE_WARNING, HTTP_E_HEADER, "Failed to exit with status/header: %d - %s", status, header ? header : "");
+ STR_FREE(header);
+ STR_FREE(body);
+ return FAILURE;
+ }
+
+ if (php_header(TSRMLS_C) && body) {
+ PHPWRITE(body, strlen(body));
+ }
+
+ switch (status)
+ {
+ case 301: http_log(HTTP_G(log).redirect, "301-REDIRECT", header); break;
+ case 302: http_log(HTTP_G(log).redirect, "302-REDIRECT", header); break;
+ case 303: http_log(HTTP_G(log).redirect, "303-REDIRECT", header); break;
+ case 307: http_log(HTTP_G(log).redirect, "307-REDIRECT", header); break;
+ case 304: http_log(HTTP_G(log).cache, "304-CACHE", header); break;
+ case 405: http_log(HTTP_G(log).allowed_methods, "405-ALLOWED", header); break;
+ default: http_log(NULL, header, body); break;
+ }
+
+ STR_FREE(header);
+ STR_FREE(body);
+
+ zend_bailout();
+ /* fake */
+ return SUCCESS;
+}
+/* }}} */