Annotation of embedaddon/php/main/SAPI.h, revision 1.1

1.1     ! misho       1: /*
        !             2:    +----------------------------------------------------------------------+
        !             3:    | PHP Version 5                                                        |
        !             4:    +----------------------------------------------------------------------+
        !             5:    | Copyright (c) 1997-2012 The PHP Group                                |
        !             6:    +----------------------------------------------------------------------+
        !             7:    | This source file is subject to version 3.01 of the PHP license,      |
        !             8:    | that is bundled with this package in the file LICENSE, and is        |
        !             9:    | available through the world-wide-web at the following url:           |
        !            10:    | http://www.php.net/license/3_01.txt                                  |
        !            11:    | If you did not receive a copy of the PHP license and are unable to   |
        !            12:    | obtain it through the world-wide-web, please send a note to          |
        !            13:    | license@php.net so we can mail you a copy immediately.               |
        !            14:    +----------------------------------------------------------------------+
        !            15:    | Author:  Zeev Suraski <zeev@zend.com>                                |
        !            16:    +----------------------------------------------------------------------+
        !            17: */
        !            18: 
        !            19: /* $Id: SAPI.h 321634 2012-01-01 13:15:04Z felipe $ */
        !            20: 
        !            21: #ifndef SAPI_H
        !            22: #define SAPI_H
        !            23: 
        !            24: #include "zend.h"
        !            25: #include "zend_API.h"
        !            26: #include "zend_llist.h"
        !            27: #include "zend_operators.h"
        !            28: #ifdef PHP_WIN32
        !            29: #include "win95nt.h"
        !            30: #endif
        !            31: #include <sys/stat.h>
        !            32: 
        !            33: #define SAPI_OPTION_NO_CHDIR 1
        !            34: 
        !            35: #define SAPI_POST_BLOCK_SIZE 4000
        !            36: 
        !            37: #ifdef PHP_WIN32
        !            38: #      ifdef SAPI_EXPORTS
        !            39: #              define SAPI_API __declspec(dllexport) 
        !            40: #      else
        !            41: #              define SAPI_API __declspec(dllimport) 
        !            42: #      endif
        !            43: #elif defined(__GNUC__) && __GNUC__ >= 4
        !            44: #      define SAPI_API __attribute__ ((visibility("default")))
        !            45: #else
        !            46: #      define SAPI_API
        !            47: #endif
        !            48: 
        !            49: #undef shutdown
        !            50: 
        !            51: typedef struct {
        !            52:        char *header;
        !            53:        uint header_len;
        !            54: } sapi_header_struct;
        !            55: 
        !            56: 
        !            57: typedef struct {
        !            58:        zend_llist headers;
        !            59:        int http_response_code;
        !            60:        unsigned char send_default_content_type;
        !            61:        char *mimetype;
        !            62:        char *http_status_line;
        !            63: } sapi_headers_struct;
        !            64: 
        !            65: 
        !            66: typedef struct _sapi_post_entry sapi_post_entry;
        !            67: typedef struct _sapi_module_struct sapi_module_struct;
        !            68: 
        !            69: BEGIN_EXTERN_C()
        !            70: extern SAPI_API sapi_module_struct sapi_module;  /* true global */
        !            71: END_EXTERN_C()
        !            72: 
        !            73: /* Some values in this structure needs to be filled in before
        !            74:  * calling sapi_activate(). We WILL change the `char *' entries,
        !            75:  * so make sure that you allocate a separate buffer for them
        !            76:  * and that you free them after sapi_deactivate().
        !            77:  */
        !            78: 
        !            79: typedef struct {
        !            80:        const char *request_method;
        !            81:        char *query_string;
        !            82:        char *post_data, *raw_post_data;
        !            83:        char *cookie_data;
        !            84:        long content_length;
        !            85:        uint post_data_length, raw_post_data_length;
        !            86: 
        !            87:        char *path_translated;
        !            88:        char *request_uri;
        !            89: 
        !            90:        const char *content_type;
        !            91: 
        !            92:        zend_bool headers_only;
        !            93:        zend_bool no_headers;
        !            94:        zend_bool headers_read;
        !            95: 
        !            96:        sapi_post_entry *post_entry;
        !            97: 
        !            98:        char *content_type_dup;
        !            99: 
        !           100:        /* for HTTP authentication */
        !           101:        char *auth_user;
        !           102:        char *auth_password;
        !           103:        char *auth_digest;
        !           104: 
        !           105:        /* this is necessary for the CGI SAPI module */
        !           106:        char *argv0;
        !           107: 
        !           108:        /* this is necessary for Safe Mode */
        !           109:        char *current_user;
        !           110:        int current_user_length;
        !           111: 
        !           112:        /* this is necessary for CLI module */
        !           113:        int argc;
        !           114:        char **argv;
        !           115:        int proto_num;
        !           116: } sapi_request_info;
        !           117: 
        !           118: 
        !           119: typedef struct _sapi_globals_struct {
        !           120:        void *server_context;
        !           121:        sapi_request_info request_info;
        !           122:        sapi_headers_struct sapi_headers;
        !           123:        int read_post_bytes;
        !           124:        unsigned char headers_sent;
        !           125:        struct stat global_stat;
        !           126:        char *default_mimetype;
        !           127:        char *default_charset;
        !           128:        HashTable *rfc1867_uploaded_files;
        !           129:        long post_max_size;
        !           130:        int options;
        !           131:        zend_bool sapi_started;
        !           132:        time_t global_request_time;
        !           133:        HashTable known_post_content_types;
        !           134: } sapi_globals_struct;
        !           135: 
        !           136: 
        !           137: BEGIN_EXTERN_C()
        !           138: #ifdef ZTS
        !           139: # define SG(v) TSRMG(sapi_globals_id, sapi_globals_struct *, v)
        !           140: SAPI_API extern int sapi_globals_id;
        !           141: #else
        !           142: # define SG(v) (sapi_globals.v)
        !           143: extern SAPI_API sapi_globals_struct sapi_globals;
        !           144: #endif
        !           145: 
        !           146: SAPI_API void sapi_startup(sapi_module_struct *sf);
        !           147: SAPI_API void sapi_shutdown(void);
        !           148: SAPI_API void sapi_activate(TSRMLS_D);
        !           149: SAPI_API void sapi_deactivate(TSRMLS_D);
        !           150: SAPI_API void sapi_initialize_empty_request(TSRMLS_D);
        !           151: END_EXTERN_C()
        !           152: 
        !           153: /*
        !           154:  * This is the preferred and maintained API for 
        !           155:  * operating on HTTP headers.
        !           156:  */
        !           157: 
        !           158: /*
        !           159:  * Always specify a sapi_header_line this way:
        !           160:  *
        !           161:  *     sapi_header_line ctr = {0};
        !           162:  */
        !           163:  
        !           164: typedef struct {
        !           165:        char *line; /* If you allocated this, you need to free it yourself */
        !           166:        uint line_len;
        !           167:        long response_code; /* long due to zend_parse_parameters compatibility */
        !           168: } sapi_header_line;
        !           169: 
        !           170: typedef enum {                                 /* Parameter:                   */
        !           171:        SAPI_HEADER_REPLACE,            /* sapi_header_line*    */
        !           172:        SAPI_HEADER_ADD,                        /* sapi_header_line*    */
        !           173:        SAPI_HEADER_DELETE,                     /* sapi_header_line*    */
        !           174:        SAPI_HEADER_DELETE_ALL,         /* void                                 */
        !           175:        SAPI_HEADER_SET_STATUS          /* int                                  */
        !           176: } sapi_header_op_enum;
        !           177: 
        !           178: BEGIN_EXTERN_C()
        !           179: SAPI_API int sapi_header_op(sapi_header_op_enum op, void *arg TSRMLS_DC);
        !           180: 
        !           181: /* Deprecated functions. Use sapi_header_op instead. */
        !           182: SAPI_API int sapi_add_header_ex(char *header_line, uint header_line_len, zend_bool duplicate, zend_bool replace TSRMLS_DC);
        !           183: #define sapi_add_header(a, b, c) sapi_add_header_ex((a),(b),(c),1 TSRMLS_CC)
        !           184: 
        !           185: 
        !           186: SAPI_API int sapi_send_headers(TSRMLS_D);
        !           187: SAPI_API void sapi_free_header(sapi_header_struct *sapi_header);
        !           188: SAPI_API void sapi_handle_post(void *arg TSRMLS_DC);
        !           189: 
        !           190: SAPI_API int sapi_register_post_entries(sapi_post_entry *post_entry TSRMLS_DC);
        !           191: SAPI_API int sapi_register_post_entry(sapi_post_entry *post_entry TSRMLS_DC);
        !           192: SAPI_API void sapi_unregister_post_entry(sapi_post_entry *post_entry TSRMLS_DC);
        !           193: SAPI_API int sapi_register_default_post_reader(void (*default_post_reader)(TSRMLS_D));
        !           194: SAPI_API int sapi_register_treat_data(void (*treat_data)(int arg, char *str, zval *destArray TSRMLS_DC));
        !           195: SAPI_API int sapi_register_input_filter(unsigned int (*input_filter)(int arg, char *var, char **val, unsigned int val_len, unsigned int *new_val_len TSRMLS_DC), unsigned int (*input_filter_init)(TSRMLS_D));
        !           196: 
        !           197: SAPI_API int sapi_flush(TSRMLS_D);
        !           198: SAPI_API struct stat *sapi_get_stat(TSRMLS_D);
        !           199: SAPI_API char *sapi_getenv(char *name, size_t name_len TSRMLS_DC);
        !           200: 
        !           201: SAPI_API char *sapi_get_default_content_type(TSRMLS_D);
        !           202: SAPI_API void sapi_get_default_content_type_header(sapi_header_struct *default_header TSRMLS_DC);
        !           203: SAPI_API size_t sapi_apply_default_charset(char **mimetype, size_t len TSRMLS_DC);
        !           204: SAPI_API void sapi_activate_headers_only(TSRMLS_D);
        !           205: 
        !           206: SAPI_API int sapi_get_fd(int *fd TSRMLS_DC);
        !           207: SAPI_API int sapi_force_http_10(TSRMLS_D);
        !           208: 
        !           209: SAPI_API int sapi_get_target_uid(uid_t * TSRMLS_DC);
        !           210: SAPI_API int sapi_get_target_gid(gid_t * TSRMLS_DC);
        !           211: SAPI_API time_t sapi_get_request_time(TSRMLS_D);
        !           212: SAPI_API void sapi_terminate_process(TSRMLS_D);
        !           213: END_EXTERN_C()
        !           214: 
        !           215: struct _sapi_module_struct {
        !           216:        char *name;
        !           217:        char *pretty_name;
        !           218: 
        !           219:        int (*startup)(struct _sapi_module_struct *sapi_module);
        !           220:        int (*shutdown)(struct _sapi_module_struct *sapi_module);
        !           221: 
        !           222:        int (*activate)(TSRMLS_D);
        !           223:        int (*deactivate)(TSRMLS_D);
        !           224: 
        !           225:        int (*ub_write)(const char *str, unsigned int str_length TSRMLS_DC);
        !           226:        void (*flush)(void *server_context);
        !           227:        struct stat *(*get_stat)(TSRMLS_D);
        !           228:        char *(*getenv)(char *name, size_t name_len TSRMLS_DC);
        !           229: 
        !           230:        void (*sapi_error)(int type, const char *error_msg, ...);
        !           231: 
        !           232:        int (*header_handler)(sapi_header_struct *sapi_header, sapi_header_op_enum op, sapi_headers_struct *sapi_headers TSRMLS_DC);
        !           233:        int (*send_headers)(sapi_headers_struct *sapi_headers TSRMLS_DC);
        !           234:        void (*send_header)(sapi_header_struct *sapi_header, void *server_context TSRMLS_DC);
        !           235: 
        !           236:        int (*read_post)(char *buffer, uint count_bytes TSRMLS_DC);
        !           237:        char *(*read_cookies)(TSRMLS_D);
        !           238: 
        !           239:        void (*register_server_variables)(zval *track_vars_array TSRMLS_DC);
        !           240:        void (*log_message)(char *message);
        !           241:        time_t (*get_request_time)(TSRMLS_D);
        !           242:        void (*terminate_process)(TSRMLS_D);
        !           243: 
        !           244:        char *php_ini_path_override;
        !           245: 
        !           246:        void (*block_interruptions)(void);
        !           247:        void (*unblock_interruptions)(void);
        !           248: 
        !           249:        void (*default_post_reader)(TSRMLS_D);
        !           250:        void (*treat_data)(int arg, char *str, zval *destArray TSRMLS_DC);
        !           251:        char *executable_location;
        !           252: 
        !           253:        int php_ini_ignore;
        !           254: 
        !           255:        int (*get_fd)(int *fd TSRMLS_DC);
        !           256: 
        !           257:        int (*force_http_10)(TSRMLS_D);
        !           258: 
        !           259:        int (*get_target_uid)(uid_t * TSRMLS_DC);
        !           260:        int (*get_target_gid)(gid_t * TSRMLS_DC);
        !           261: 
        !           262:        unsigned int (*input_filter)(int arg, char *var, char **val, unsigned int val_len, unsigned int *new_val_len TSRMLS_DC);
        !           263:        
        !           264:        void (*ini_defaults)(HashTable *configuration_hash);
        !           265:        int phpinfo_as_text;
        !           266: 
        !           267:        char *ini_entries;
        !           268:        const zend_function_entry *additional_functions;
        !           269:        unsigned int (*input_filter_init)(TSRMLS_D);
        !           270: };
        !           271: 
        !           272: 
        !           273: struct _sapi_post_entry {
        !           274:        char *content_type;
        !           275:        uint content_type_len;
        !           276:        void (*post_reader)(TSRMLS_D);
        !           277:        void (*post_handler)(char *content_type_dup, void *arg TSRMLS_DC);
        !           278: };
        !           279: 
        !           280: /* header_handler() constants */
        !           281: #define SAPI_HEADER_ADD                        (1<<0)
        !           282: 
        !           283: 
        !           284: #define SAPI_HEADER_SENT_SUCCESSFULLY  1
        !           285: #define SAPI_HEADER_DO_SEND                            2
        !           286: #define SAPI_HEADER_SEND_FAILED                        3
        !           287: 
        !           288: #define SAPI_DEFAULT_MIMETYPE          "text/html"
        !           289: #define SAPI_DEFAULT_CHARSET           ""
        !           290: #define SAPI_PHP_VERSION_HEADER                "X-Powered-By: PHP/" PHP_VERSION
        !           291: 
        !           292: #define SAPI_POST_READER_FUNC(post_reader) void post_reader(TSRMLS_D)
        !           293: #define SAPI_POST_HANDLER_FUNC(post_handler) void post_handler(char *content_type_dup, void *arg TSRMLS_DC)
        !           294: 
        !           295: #define SAPI_TREAT_DATA_FUNC(treat_data) void treat_data(int arg, char *str, zval* destArray TSRMLS_DC)
        !           296: #define SAPI_INPUT_FILTER_FUNC(input_filter) unsigned int input_filter(int arg, char *var, char **val, unsigned int val_len, unsigned int *new_val_len TSRMLS_DC)
        !           297: 
        !           298: BEGIN_EXTERN_C()
        !           299: SAPI_API SAPI_POST_READER_FUNC(sapi_read_standard_form_data);
        !           300: SAPI_API SAPI_POST_READER_FUNC(php_default_post_reader);
        !           301: SAPI_API SAPI_TREAT_DATA_FUNC(php_default_treat_data);
        !           302: SAPI_API SAPI_INPUT_FILTER_FUNC(php_default_input_filter);
        !           303: END_EXTERN_C()
        !           304: 
        !           305: #define STANDARD_SAPI_MODULE_PROPERTIES
        !           306: 
        !           307: #endif /* SAPI_H */
        !           308: 
        !           309: /*
        !           310:  * Local variables:
        !           311:  * tab-width: 4
        !           312:  * c-basic-offset: 4
        !           313:  * End:
        !           314:  */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>