|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
?? ??? 2002, Version 4.3.0
- If possible set Content-Length header in zlib.output_compression mode. (thies)
-- Added session_set_userdata() which enables you to specify one variable that
- will be kept in the browser in addition to the session-id.
- Note: This only works with trans-sid sessions (no cookie). (thies)
- Major update of domxml. New functions and better DOM compliance. (Uwe)
- Added large OID value (2^31 to 2^32) support for pg_lo_import(),
pg_lo_unlink(), pg_lo_open() and pg_lo_export(). (Yasuo)
char *save_path;
char *session_name;
char *id;
- char *udata_name;
- char *udata_value;
char *extern_referer_chk;
char *entropy_file;
char *cache_limiter;
PHP_FUNCTION(session_set_cookie_params);
PHP_FUNCTION(session_get_cookie_params);
PHP_FUNCTION(session_write_close);
-PHP_FUNCTION(session_set_userdata);
#ifdef ZTS
#define PS(v) TSRMG(ps_globals_id, php_ps_globals *, v)
PHP_FE(session_set_cookie_params, NULL)
PHP_FE(session_get_cookie_params, NULL)
PHP_FE(session_write_close, NULL)
- PHP_FE(session_set_userdata, NULL)
{NULL, NULL, NULL}
};
/* }}} */
-#define SAFE_STRING(s) ((s)?(s):"")
-
ZEND_DECLARE_MODULE_GLOBALS(ps);
static ps_module *_php_find_ps_module(char *name TSRMLS_DC);
static void php_session_output_handler(char *output, uint output_len, char **handled_output, uint *handled_output_len, int mode TSRMLS_DC)
{
if ((PS(session_status) == php_session_active)) {
- *handled_output = url_adapt_ext_ex(output, output_len, PS(session_name), PS(id), SAFE_STRING(PS(udata_name)), SAFE_STRING(PS(udata_value)), handled_output_len, (zend_bool) (mode&PHP_OUTPUT_HANDLER_END ? 1 : 0) TSRMLS_CC);
+ *handled_output = url_adapt_ext_ex(output, output_len, PS(session_name), PS(id), handled_output_len, (zend_bool) (mode&PHP_OUTPUT_HANDLER_END ? 1 : 0) TSRMLS_CC);
} else {
*handled_output = NULL;
}
}
/* }}} */
-/* {{{ proto bool session_set_userdata(string var, string value)
- sets one additional variable that will be added by in trans-SID mode */
-PHP_FUNCTION(session_set_userdata)
-{
- zval **str;
- zval **val;
-
- if (ZEND_NUM_ARGS() != 2 || zend_get_parameters_ex(2, &str, &val) == FAILURE)
- WRONG_PARAM_COUNT;
-
- if ((Z_TYPE_PP(str) != IS_STRING) || (Z_TYPE_PP(val) != IS_STRING)) {
- php_error(E_ERROR,"session_set_userdata expects both parameters to be strings");
- RETURN_FALSE;
- }
-
- PS(udata_name) = estrndup(Z_STRVAL_PP(str), Z_STRLEN_PP(str));
- PS(udata_value) = estrndup(Z_STRVAL_PP(val), Z_STRLEN_PP(val));
-
- RETURN_TRUE;
-}
-/* }}} */
PHPAPI void session_adapt_url(const char *url, size_t urllen, char **new, size_t *newlen TSRMLS_DC)
{
if (PS(apply_trans_sid) && (PS(session_status) == php_session_active)) {
- *new = url_adapt_single_url(url, urllen, PS(session_name), PS(id), PS(udata_name), PS(udata_value), newlen TSRMLS_CC);
+ *new = url_adapt_single_url(url, urllen, PS(session_name), PS(id), newlen TSRMLS_CC);
}
}
if (PS(id)) {
efree(PS(id));
}
-
- if (PS(udata_name)) {
- efree(PS(udata_name));
- PS(udata_name) = NULL;
- }
-
- if (PS(udata_value)) {
- efree(PS(udata_value));
- PS(udata_value) = NULL;
- }
-
zend_hash_destroy(&PS(vars));
}
-/* Generated by re2c 0.5 on Sat Apr 28 00:00:01 2002 */
+/* Generated by re2c 0.5 on Sun Apr 28 13:43:23 2002 */
#line 1 "/home/thies/devel/php4/ext/standard/url_scanner_ex.re"
/*
+----------------------------------------------------------------------+
#define YYLIMIT q
#define YYMARKER r
-static inline void append_modified_url(smart_str *url, smart_str *dest, smart_str *name, smart_str *val, smart_str *udata_name, smart_str *udata_value, const char *separator)
+static inline void append_modified_url(smart_str *url, smart_str *dest, smart_str *name, smart_str *val, const char *separator)
{
register const char *p, *q;
const char *bash = NULL;
smart_str_append(dest, name);
smart_str_appendc(dest, '=');
smart_str_append(dest, val);
- if (udata_name->len && udata_value->len) {
- smart_str_appends(dest, separator);
- smart_str_append(dest, udata_name);
- smart_str_appendc(dest, '=');
- smart_str_append(dest, udata_value);
- }
if (bash)
smart_str_appendl(dest, bash, q - bash);
if (quotes)
smart_str_appendc(&ctx->result, type);
if (f) {
- append_modified_url(&ctx->val, &ctx->result, &ctx->q_name, &ctx->q_value, &ctx->q_udata_name, &ctx->q_udata_value, PG(arg_separator).output);
+ append_modified_url(&ctx->val, &ctx->result, &ctx->q_name, &ctx->q_value, PG(arg_separator).output);
} else {
smart_str_append(&ctx->result, &ctx->val);
}
smart_str_appends(&ctx->result, "\" value=\"");
smart_str_append(&ctx->result, &ctx->q_value);
smart_str_appends(&ctx->result, "\" />");
-
- if (ctx->q_udata_name.len) {
- smart_str_appends(&ctx->result, "<input type=\"hidden\" name=\"");
- smart_str_append(&ctx->result, &ctx->q_udata_name);
- smart_str_appends(&ctx->result, "\" value=\"");
- smart_str_append(&ctx->result, &ctx->q_udata_value);
- smart_str_appends(&ctx->result, "\" />");
- }
}
}
if(yybm[0+yych] & 128) goto yy15;
yy13: yych = *++YYCURSOR;
yy14:
-#line 277
+#line 263
{ passthru(STD_ARGS); STATE = STATE_TAG; goto state_tag; }
yy15: ++YYCURSOR;
if(YYLIMIT == YYCURSOR) YYFILL(1);
yych = *YYCURSOR;
yy16: if(yybm[0+yych] & 128) goto yy15;
yy17:
-#line 278
+#line 264
{ passthru(STD_ARGS); goto state_plain; }
}
-#line 279
+#line 265
state_tag:
yy20: yych = *++YYCURSOR;
goto yy25;
yy21:
-#line 284
+#line 270
{ handle_tag(STD_ARGS); /* Sets STATE */; passthru(STD_ARGS); if (STATE == STATE_PLAIN) goto state_plain; else goto state_next_arg; }
yy22: yych = *++YYCURSOR;
yy23:
-#line 285
+#line 271
{ passthru(STD_ARGS); goto state_plain_begin; }
yy24: ++YYCURSOR;
if(YYLIMIT == YYCURSOR) YYFILL(1);
yy25: if(yybm[0+yych] & 128) goto yy24;
goto yy21;
}
-#line 286
+#line 272
state_next_arg_begin:
}
yy28: yych = *++YYCURSOR;
yy29:
-#line 294
+#line 280
{ passthru(STD_ARGS); handle_form(STD_ARGS); goto state_plain_begin; }
yy30: yych = *++YYCURSOR;
goto yy37;
yy31:
-#line 295
+#line 281
{ passthru(STD_ARGS); goto state_next_arg; }
yy32: yych = *++YYCURSOR;
yy33:
-#line 296
+#line 282
{ --YYCURSOR; STATE = STATE_ARG; goto state_arg; }
yy34: yych = *++YYCURSOR;
yy35:
-#line 297
+#line 283
{ passthru(STD_ARGS); goto state_plain_begin; }
yy36: ++YYCURSOR;
if(YYLIMIT == YYCURSOR) YYFILL(1);
yy37: if(yybm[0+yych] & 128) goto yy36;
goto yy31;
}
-#line 298
+#line 284
state_arg:
yy40: yych = *++YYCURSOR;
goto yy45;
yy41:
-#line 303
+#line 289
{ passthru(STD_ARGS); handle_arg(STD_ARGS); STATE = STATE_BEFORE_VAL; goto state_before_val; }
yy42: yych = *++YYCURSOR;
yy43:
-#line 304
+#line 290
{ passthru(STD_ARGS); STATE = STATE_NEXT_ARG; goto state_next_arg; }
yy44: ++YYCURSOR;
if(YYLIMIT == YYCURSOR) YYFILL(1);
yy45: if(yybm[0+yych] & 128) goto yy44;
goto yy41;
}
-#line 305
+#line 291
state_before_val:
if(yych == ' ') goto yy55;
if(yych == '=') goto yy53;
yy49:
-#line 311
+#line 297
{ --YYCURSOR; goto state_next_arg_begin; }
yy50: yych = *++YYCURSOR;
goto yy54;
yy51:
-#line 310
+#line 296
{ passthru(STD_ARGS); STATE = STATE_VAL; goto state_val; }
yy52: yych = *++YYCURSOR;
goto yy49;
case 0: goto yy49;
}
}
-#line 312
+#line 298
yych = *(YYMARKER = ++YYCURSOR);
if(yych != '>') goto yy74;
yy61:
-#line 321
+#line 307
{ passthru(STD_ARGS); goto state_next_arg_begin; }
yy62: yyaccept = 0;
yych = *(YYMARKER = ++YYCURSOR);
yy63: yych = *++YYCURSOR;
goto yy67;
yy64:
-#line 320
+#line 306
{ handle_val(STD_ARGS, 0, '"'); goto state_next_arg_begin; }
yy65: yych = *++YYCURSOR;
goto yy61;
}
yy71: yych = *++YYCURSOR;
yy72:
-#line 319
+#line 305
{ handle_val(STD_ARGS, 1, '\''); goto state_next_arg_begin; }
yy73: ++YYCURSOR;
if(YYLIMIT == YYCURSOR) YYFILL(1);
if(yych >= '>') goto yy70;
yy75: yych = *++YYCURSOR;
yy76:
-#line 318
+#line 304
{ handle_val(STD_ARGS, 1, '"'); goto state_next_arg_begin; }
}
-#line 322
+#line 308
stop:
}
-char *url_adapt_single_url(const char *url, size_t urllen, const char *name, const char *value, char *udata_name, char *udata_value, size_t *newlen TSRMLS_DC)
+char *url_adapt_single_url(const char *url, size_t urllen, const char *name, const char *value, size_t *newlen TSRMLS_DC)
{
smart_str surl = {0};
smart_str buf = {0};
smart_str sname = {0};
smart_str sval = {0};
- smart_str aname = {0};
- smart_str avalue = {0};
smart_str_setl(&surl, url, urllen);
smart_str_sets(&sname, name);
smart_str_sets(&sval, value);
- smart_str_sets(&aname, udata_name);
- smart_str_sets(&avalue, udata_value);
- append_modified_url(&surl, &buf, &sname, &sval, &aname, &avalue, PG(arg_separator).output);
+ append_modified_url(&surl, &buf, &sname, &sval, PG(arg_separator).output);
smart_str_0(&buf);
if (newlen) *newlen = buf.len;
return buf.c;
}
-char *url_adapt_ext(const char *src, size_t srclen, const char *name, const char *value, char *udata_name, char *udata_value, size_t *newlen, zend_bool do_flush TSRMLS_DC)
+char *url_adapt_ext(const char *src, size_t srclen, const char *name, const char *value, size_t *newlen, zend_bool do_flush TSRMLS_DC)
{
url_adapt_state_ex_t *ctx;
char *retval;
smart_str_sets(&ctx->q_name, name);
smart_str_sets(&ctx->q_value, value);
-
- smart_str_sets(&ctx->q_udata_name, udata_name);
- smart_str_sets(&ctx->q_udata_value, udata_value);
-
xx_mainloop(ctx, src, srclen TSRMLS_CC);
*newlen = ctx->result.len;
int php_url_scanner_ex_activate(TSRMLS_D);
int php_url_scanner_ex_deactivate(TSRMLS_D);
-char *url_adapt_ext_ex(const char *src, size_t srclen, const char *name, const char *value, char *udata_name, char *udata_value, size_t *newlen, zend_bool do_flush TSRMLS_DC);
+char *url_adapt_ext_ex(const char *src, size_t srclen, const char *name, const char *value, size_t *newlen, zend_bool do_flush TSRMLS_DC);
-char *url_adapt_single_url(const char *url, size_t urllen, const char *name, const char *value, char *udata_name, char *udata_value, size_t *newlen TSRMLS_DC);
+char *url_adapt_single_url(const char *url, size_t urllen, const char *name, const char *value, size_t *newlen TSRMLS_DC);
char *url_adapt_flush(size_t * TSRMLS_DC);
smart_str q_name;
smart_str q_value;
- smart_str q_udata_name;
- smart_str q_udata_value;
-
char *lookup_data;
int state;
#define YYLIMIT q
#define YYMARKER r
-static inline void append_modified_url(smart_str *url, smart_str *dest, smart_str *name, smart_str *val, smart_str *udata_name, smart_str *udata_value, const char *separator)
+static inline void append_modified_url(smart_str *url, smart_str *dest, smart_str *name, smart_str *val, const char *separator)
{
register const char *p, *q;
const char *bash = NULL;
smart_str_append(dest, name);
smart_str_appendc(dest, '=');
smart_str_append(dest, val);
- if (udata_name->len && udata_value->len) {
- smart_str_appends(dest, separator);
- smart_str_append(dest, udata_name);
- smart_str_appendc(dest, '=');
- smart_str_append(dest, udata_value);
- }
if (bash)
smart_str_appendl(dest, bash, q - bash);
if (quotes)
smart_str_appendc(&ctx->result, type);
if (f) {
- append_modified_url(&ctx->val, &ctx->result, &ctx->q_name, &ctx->q_value, &ctx->q_udata_name, &ctx->q_udata_value, PG(arg_separator).output);
+ append_modified_url(&ctx->val, &ctx->result, &ctx->q_name, &ctx->q_value, PG(arg_separator).output);
} else {
smart_str_append(&ctx->result, &ctx->val);
}
smart_str_appends(&ctx->result, "\" value=\"");
smart_str_append(&ctx->result, &ctx->q_value);
smart_str_appends(&ctx->result, "\" />");
-
- if (ctx->q_udata_name.len) {
- smart_str_appends(&ctx->result, "<input type=\"hidden\" name=\"");
- smart_str_append(&ctx->result, &ctx->q_udata_name);
- smart_str_appends(&ctx->result, "\" value=\"");
- smart_str_append(&ctx->result, &ctx->q_udata_value);
- smart_str_appends(&ctx->result, "\" />");
- }
}
}
}
-char *url_adapt_single_url(const char *url, size_t urllen, const char *name, const char *value, char *udata_name, char *udata_value, size_t *newlen TSRMLS_DC)
+char *url_adapt_single_url(const char *url, size_t urllen, const char *name, const char *value, size_t *newlen TSRMLS_DC)
{
smart_str surl = {0};
smart_str buf = {0};
smart_str sname = {0};
smart_str sval = {0};
- smart_str aname = {0};
- smart_str avalue = {0};
smart_str_setl(&surl, url, urllen);
smart_str_sets(&sname, name);
smart_str_sets(&sval, value);
- smart_str_sets(&aname, udata_name);
- smart_str_sets(&avalue, udata_value);
- append_modified_url(&surl, &buf, &sname, &sval, &aname, &avalue, PG(arg_separator).output);
+ append_modified_url(&surl, &buf, &sname, &sval, PG(arg_separator).output);
smart_str_0(&buf);
if (newlen) *newlen = buf.len;
return buf.c;
}
-char *url_adapt_ext(const char *src, size_t srclen, const char *name, const char *value, char *udata_name, char *udata_value, size_t *newlen, zend_bool do_flush TSRMLS_DC)
+char *url_adapt_ext(const char *src, size_t srclen, const char *name, const char *value, size_t *newlen, zend_bool do_flush TSRMLS_DC)
{
url_adapt_state_ex_t *ctx;
char *retval;
smart_str_sets(&ctx->q_name, name);
smart_str_sets(&ctx->q_value, value);
-
- smart_str_sets(&ctx->q_udata_name, udata_name);
- smart_str_sets(&ctx->q_udata_value, udata_value);
-
xx_mainloop(ctx, src, srclen TSRMLS_CC);
*newlen = ctx->result.len;