diff options
| author | George Schlossnagle <gschlossnagle@php.net> | 2002-11-18 01:01:21 +0000 | 
|---|---|---|
| committer | George Schlossnagle <gschlossnagle@php.net> | 2002-11-18 01:01:21 +0000 | 
| commit | 824fdad6c11173937c08b0dbff7ad6afc2ac3e05 (patch) | |
| tree | ee1286b71a39f5386f20ac46ef8075c8d9cfc70d /sapi/apache_hooks/sapi_apache.c | |
| parent | 99c7ddc3a8f9ecf1a3968f6e59dc9d95106bb0c7 (diff) | |
| download | php-git-824fdad6c11173937c08b0dbff7ad6afc2ac3e05.tar.gz | |
initial import of all these files.  This was previously the apache_hooks
branch of the apache sapi.  Now it lives on its own.  General functionality
seems to be working, though there may be a problem with some
output buffering, most likely due to the way that sapi_deactivate needs
to be mangled with here.
Diffstat (limited to 'sapi/apache_hooks/sapi_apache.c')
| -rw-r--r-- | sapi/apache_hooks/sapi_apache.c | 138 | 
1 files changed, 138 insertions, 0 deletions
| diff --git a/sapi/apache_hooks/sapi_apache.c b/sapi/apache_hooks/sapi_apache.c new file mode 100644 index 0000000000..29bd26483b --- /dev/null +++ b/sapi/apache_hooks/sapi_apache.c @@ -0,0 +1,138 @@ +/* +   +----------------------------------------------------------------------+ +   | PHP Version 4                                                        | +   +----------------------------------------------------------------------+ +   | Copyright (c) 1997-2002 The PHP Group                                | +   +----------------------------------------------------------------------+ +   | This source file is subject to version 2.02 of the PHP license,      | +   | that is bundled with this package in the file LICENSE, and is        | +   | available at through the world-wide-web at                           | +   | http://www.php.net/license/2_02.txt.                                 | +   | If you did not receive a copy of the PHP license and are unable to   | +   | obtain it through the world-wide-web, please send a note to          | +   | license@php.net so we can mail you a copy immediately.               | +   +----------------------------------------------------------------------+ +   | Authors: Rasmus Lerdorf <rasmus@php.net>                             | +   | (with helpful hints from Dean Gaudet <dgaudet@arctic.org>            | +   | PHP 4.0 patches by:                                                  | +   | Zeev Suraski <zeev@zend.com>                                         | +   | Stig Bakken <ssb@fast.no>                                            | +   +----------------------------------------------------------------------+ + */ +/* $Id$ */ + +#include "php_apache_http.h" + +/* {{{ apache_php_module_main + */ +int apache_php_module_main(request_rec *r, int display_source_mode TSRMLS_DC) +{ +	zend_file_handle file_handle; + +	if (php_request_startup(TSRMLS_C) == FAILURE) { +		return FAILURE; +	} +	/* sending a file handle to another dll is not working +	// so let zend open it.  +	*/ +	 +	if (display_source_mode) { +		zend_syntax_highlighter_ini syntax_highlighter_ini; + +		php_get_highlight_struct(&syntax_highlighter_ini); +		if (highlight_file(SG(request_info).path_translated, &syntax_highlighter_ini TSRMLS_CC)){ +			return OK; +		} else { +			return NOT_FOUND; +		} +	} else { +		file_handle.type = ZEND_HANDLE_FILENAME; +		file_handle.handle.fd = 0; +		file_handle.filename = SG(request_info).path_translated; +		file_handle.opened_path = NULL; +		file_handle.free_filename = 0; +		(void) php_execute_script(&file_handle TSRMLS_CC); +	} +	AP(in_request) = 0; +	 +	return (OK); +} +/* }}} */ + +/* {{{ apache_php_module_hook + */ +int apache_php_module_hook(request_rec *r, php_handler *handler, zval **ret TSRMLS_DC) +{ +	zend_file_handle file_handle; +	zval *req; +    char *tmp; + +#if PHP_SIGCHILD +	signal(SIGCHLD, sigchld_handler); +#endif +    if(AP(current_hook) == AP_RESPONSE) { +        fprintf(stderr, "in Response\n"); +        if (php_request_startup_for_hook(TSRMLS_C) == FAILURE) +            return FAILURE; +    } +    else { +        if (php_request_startup_for_hook(TSRMLS_C) == FAILURE) +            return FAILURE; +    } + +	req = php_apache_request_new(r); +    if(PG(register_globals)) { +        php_register_variable_ex("request", req, NULL TSRMLS_CC); +    } +    else { +        php_register_variable_ex("request", req, PG(http_globals)[TRACK_VARS_SERVER] TSRMLS_CC); +    } +    switch(handler->type) { +        case AP_HANDLER_TYPE_FILE: +            php_register_variable("PHP_SELF_HOOK", handler->name, PG(http_globals)[TRACK_VARS_SERVER] TSRMLS_CC); +	        memset(&file_handle, 0, sizeof(file_handle)); +	        file_handle.type = ZEND_HANDLE_FILENAME; +	        file_handle.filename = handler->name; +	        (void) php_execute_simple_script(&file_handle, ret TSRMLS_CC); +            break; +        case AP_HANDLER_TYPE_METHOD: +            if( (tmp = strstr(handler->name, "::")) != NULL &&  *(tmp+2) != '\0' ) { +                zval *class; +                zval *method; +                *tmp = '\0'; +                ALLOC_ZVAL(class); +                ZVAL_STRING(class, handler->name, 1); +                ALLOC_ZVAL(method); +                ZVAL_STRING(method, tmp +2, 1); +                fprintf(stderr, "calling coderef %s::%s\n", handler->name, tmp +2); +                *tmp = ':'; +                call_user_function_ex(EG(function_table), &class, method, ret, 0, NULL, 0, NULL TSRMLS_CC); +                zval_dtor(&class); +                zval_dtor(&method); +            } +            else { +                php_error(E_ERROR, "Unable to call %s - not a Class::Method\n", handler->name); +                /* not a class::method */ +            } +            break; +        default: +            /* not a valid type */ +            assert(0); +            break; +    } +	zval_dtor(&req); +	AP(in_request) = 0; + +	return OK; +} + +/* }}} */ + +/* + * Local variables: + * tab-width: 4 + * c-basic-offset: 4 + * End: + * vim600: sw=4 ts=4 fdm=marker + * vim<600: sw=4 ts=4 + */ | 
