diff options
| author | Derick Rethans <derick@php.net> | 2006-01-31 08:11:35 +0000 | 
|---|---|---|
| committer | Derick Rethans <derick@php.net> | 2006-01-31 08:11:35 +0000 | 
| commit | 657d5f086f3b7d024ea6747e66aa41f379f2f2c6 (patch) | |
| tree | 13e2e903d96cdcdc0402ffb6a88be67b1efb0f3d | |
| parent | b22ab5b5d37f2ebf131d1831ad28a71b8e44ceca (diff) | |
| download | php-git-657d5f086f3b7d024ea6747e66aa41f379f2f2c6.tar.gz | |
- Moved msession to PECL.
| -rw-r--r-- | NEWS | 2 | ||||
| -rw-r--r-- | ext/msession/CREDITS | 3 | ||||
| -rw-r--r-- | ext/msession/README | 33 | ||||
| -rw-r--r-- | ext/msession/config.m4 | 36 | ||||
| -rw-r--r-- | ext/msession/msession-test.php | 125 | ||||
| -rw-r--r-- | ext/msession/msession.c | 1375 | ||||
| -rw-r--r-- | ext/msession/msession.php | 10 | ||||
| -rw-r--r-- | ext/msession/php_msession.h | 106 | ||||
| -rw-r--r-- | ext/msession/reqclient.h | 171 | 
9 files changed, 2 insertions, 1859 deletions
| @@ -1,6 +1,8 @@  PHP                                                                        NEWS  |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||  ?? ??? 2006, PHP 5.1.3 +- Moved extensions to PECL: +  . ext/msession (Derick)  - Improved cURL extension: (Ilia)    . Added curl_setopt_array() function that allows setting of multiple options      via an associated array. diff --git a/ext/msession/CREDITS b/ext/msession/CREDITS deleted file mode 100644 index 4703783a74..0000000000 --- a/ext/msession/CREDITS +++ /dev/null @@ -1,3 +0,0 @@ -msession -Mark L. Woodward -mailto:mlwmohawk@mohawksoft.com diff --git a/ext/msession/README b/ext/msession/README deleted file mode 100644 index a4ed70faed..0000000000 --- a/ext/msession/README +++ /dev/null @@ -1,33 +0,0 @@ -This is msession, it is an interface to a stand-alone session -management system. The msession daemon can be found at  -Mohawk Software's web site. - -http://www.mohawksoft.com - -Requirements: -Mohawk Software's Phoenix library. -Mohawk Software's msession daemon. - -Building: -In the config.m4 file you will need to specify the include  -and library directories for Phoenix. The setting in config.m4 -is probably wrong. - -You will need phoenix installed and built to compile this -module. - -To use msession-test.php, msession must be the default session -handler in PHP. The easiest way to do that is in the php.ini -file as: - -[Session] -session.save_handler = msession -session.save_path = localhost - -The session.save.path is the host name of the server running -msessiond. - -12/22/2001 -Changed msession_getdata(...) to msession_get_data(...) -Changed msession_setdata(...) to msession_set_data(...) -(docs to follow) diff --git a/ext/msession/config.m4 b/ext/msession/config.m4 deleted file mode 100644 index f41d018c6d..0000000000 --- a/ext/msession/config.m4 +++ /dev/null @@ -1,36 +0,0 @@ -dnl -dnl $Id$ -dnl - -PHP_ARG_WITH(msession, for msession support, -[  --with-msession[=DIR]   Include msession support]) -  -if test "$PHP_MSESSION" != "no"; then -	if test -r $PHP_MSESSION/lib/libphoenix.a; then -		PHOENIX_DIR=$PHP_MSESSION -	else -		AC_MSG_CHECKING(for msession in default path) -		for i in /usr/local/phoenix /usr/local /usr; do -			if test -r $i/lib/libphoenix.a; then -				PHOENIX_DIR=$i -				AC_MSG_RESULT(found in $i) -			fi -		done -	fi - -	if test -z "$PHOENIX_DIR"; then -		AC_MSG_RESULT(not found) -		AC_MSG_ERROR(Please reinstall the Phoenix / msession distribution) -	fi - - -  	AC_DEFINE(HAVE_MSESSION, 1, [ ]) -  	PHP_ADD_LIBRARY_WITH_PATH(phoenix, "$PHOENIX_DIR/lib", PHOENIX_LIB) -	PHOENIX_INCLUDE="-I$PHOENIX_DIR" -	PHP_SUBST(PHOENIX_LIB) - -  	PHP_REQUIRE_CXX -  	PHP_NEW_EXTENSION(msession, msession.c, $ext_shared) -  	PHP_ADD_LIBRARY(stdc++) -fi - diff --git a/ext/msession/msession-test.php b/ext/msession/msession-test.php deleted file mode 100644 index e591fcca70..0000000000 --- a/ext/msession/msession-test.php +++ /dev/null @@ -1,125 +0,0 @@ -<? -#	msession-test.php -#	This is a test page for msession functions. -#	most msession functions are used in this page with -#	the exception of msession_get_data, and msession_set_data -#	which are used implicitly with the PHP session -#	extension. -# -#  -# - -# Start the session system, this will connect to msession -# as configured in PHP.INI. -# -# Start sessions, this will set a cookie. -session_start(); - -# Now, optional, use msession_uniq() to create a guarenteed -# uniq session name. -#  -if(!$HTTP_COOKIE_VARS["PHPSESSID"]) -{ -	# Use uniq to create the session. This is guarenteed to be -	# uniq in the server. -	$sid = msession_uniq(32); -	setcookie ("PHPSESSID", $sid); -	session_id($sid); -	$HTTP_COOKIE_VARS["PHPSESSID"] = $sid; -	# New session, set some variables -	if(0) // One at a time -	{ -		echo "Set Variable: " . msession_set($sid, 'time',time()) ."<p>\n"; -		echo "Set Variable: " . msession_set($sid, 'name1','test1') ."<p>\n"; -		echo "Set Variable: " . msession_set($sid, 'name2','test2') ."<p>\n"; -		echo "Set Variable: " . msession_set($sid, 'name3','test3') ."<p>\n"; -		echo "Set Variable: " . msession_set($sid, 'name4','test4') ."<p>\n"; -		echo "Set Variable: " . msession_set($sid, 'name5','test5') ."<p>\n"; -		echo "Set Variable: " . msession_set($sid, 'name6','test6') ."<p>\n"; -		echo "Set Variable: " . msession_set($sid, 'name7','test7') ."<p>\n"; -	} -	else // All at once in an array -	{ -		$setarray = array(); -		$setarray['time']=time(); -		$setarray['name1'] = 'test1'; -		$setarray['name2'] = 'test2'; -		$setarray['name3'] = 'test3'; -		$setarray['name4'] = 'test4'; -		$setarray['name5'] = 'test5'; -		$setarray['name6'] = 'test6'; -		$setarray['name7'] = 'test7'; -		msession_set_array($sid, $setarray); -	} -} -else -{ -	$sid = $HTTP_COOKIE_VARS["PHPSESSID"]; -} - -#This makes a link between the variable $count and the -# session variable "count" -session_register("count"); - -$count ++; - -# Output some information. -echo "sid: " . $sid . "<br>\n"; -echo "Session Count: " . $count . "<br>\n"; - -# Use msession_randstr() to produce a random string. -# A valid string of n characters of jibberish is returned. -echo "Random String: " . msession_randstr(32) . "<br>\n"; - -# This is a thread safe increment, unlike PHP's session, many web servers -# can be updating this variable and collisions are managed. -# (for this to work, older versions of msessiond must be started with "-g globals" -#  newer versions create it by default) -echo "Global Count: " . msession_inc(globals, "counter") . "<br>\n"; - -# This gets a count of active sessions. -echo "Total active sessions: " . msession_count() . "<br>\n"; - -# This gets all the variables for a user in an associative array. -$varray = msession_get_array($sid); - -if(!$varray) -	echo "Get variable array: Failed<br>\n"; - -# Display all the user's variables -$arraykeys = array_keys($varray); -for($i=0; $arraykeys[$i]; $i++) -	echo "Key: " . $arraykeys[ $i ] ." = " .$varray[$arraykeys[$i]] ."<br>\n"; - -	 -# Find a list of all sessions with same name/value pair -$array = msession_find('name1', 'test1'); - -#display the sessions -for($i=0; $array[$i]; $i++) -	echo "Similar Sessions: " . $i . " " . $array[$i] . "<br>\n"; - -# Find all the sessions which have the variable "time" set. -$vararray = msession_listvar('time'); - -$arraykeys = array_keys($vararray); - -for($i=0; $arraykeys[$i]; $i++) -	echo "Key: " . $arraykeys[ $i ] ." = " .$vararray[$arraykeys[$i]] ."<br>\n"; - -# msession can support a personality plugin, this is an escape call directly -# into the plugin's REQ_ESCAPE function. -echo "Call the plugin: " . msession_plugin($sid, 3, "test"). "<br>\n"; - -# msession also supprts function-only plugins. this is a call into the demo -# plugin (funct.so) which returns the uptime of the msessiond process.  -echo "Call the function: " . msession_call('fntest', "1","2", "3", "4") ."<br>\n";  - -#List ALL sessions on the system -$sarray = msession_list(); - -for($i=0; $sarray[$i]; $i++) -	echo "Sessions: " . $i . " " . $sarray[$i] . "<br>\n"; - -?> - diff --git a/ext/msession/msession.c b/ext/msession/msession.c deleted file mode 100644 index 9f218300e2..0000000000 --- a/ext/msession/msession.c +++ /dev/null @@ -1,1375 +0,0 @@ -/* -   +----------------------------------------------------------------------+ -   | msession 1.0                                                         | -   +----------------------------------------------------------------------+ -   | Copyright (c) 1997-2006 The PHP Group                                | -   +----------------------------------------------------------------------+ -   | This source file is subject to version 3.01 of the PHP license,      | -   | that is bundled with this package in the file LICENSE, and is        | -   | available through the world-wide-web at the following url:           | -   | http://www.php.net/license/3_01.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: Mark Woodward <markw@mohawksoft.com>                        | -   |    Portions copyright the PHP group.                                 | -   +----------------------------------------------------------------------+ - */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "php.h" -#include "php_ini.h" -#include "php_msession.h" -#include "reqclient.h" -#include "ext/standard/info.h" -#include "ext/session/php_session.h" - - -/* Macros and such */ -#ifndef TRUE -#define TRUE 1 -#endif -#ifndef FALSE -#define FALSE 0 -#endif -#ifndef SID_LEN -#define SID_LEN 32 -#endif - - -/* Uncomment to get debugging messages */ -/* #define ERR_DEBUG */ - -#ifdef ERR_DEBUG -#define ELOG( str )	php_log_err( str ) -#else -#define ELOG( str ) -#endif - -/* Test if system is OK fror use. */ -/* Macros may be ugly, but I can globaly add debuging when needed. */ -#define	IFCONNECT_BEGIN		if(s_reqb && s_conn) { -#define IFCONNECT_ENDVAL(V) 	} else { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Msession not initialized"); return V; } -#define IFCONNECT_END		} else { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Msession not initialized"); RETURN_FALSE; } - -#ifndef HAVE_PHP_SESSION -#error HAVE_PHP_SESSION not defined -#endif - -/* Test if session module contains custom sesson ID patch */ -#ifdef PHP_SESSION_API -#if (PHP_SESSION_API >= 20020330) -#define HAVE_PHP_SESSION_CREATESID -#endif -#endif -	 -/* This sets the PHP API version used in the file. */ -/* If this module does not compile on the version of PHP you are using, look for */ -/* this value in Zend/zend_modules.h, and set appropriately */ -#if (ZEND_MODULE_API_NO <=  20001222) -#define PHP_4_0 -#define TSRMLS_CC -#define TSRMLS_DC -#define TSRMLS_FETCH() -/* Comment out this line if you wish to have msession without php sessions */ -#define HAVE_PHP_SESSION -#warning Backward compatible msession extension requires PHP sessions. If PHP compiles and links, you can ignore this warning. -#elif (ZEND_MODULE_API_NO >= 20010901) -#define PHP_4_1 -#else -#warning ZEND_MODULE_API_NO not defined -#define PHP_4_1 -#endif - -/* - * Please do not remove backward compatibility from this module. - * this same source must also work with the 4.0.6 version of PHP. - * - * Module Variable naming hints: - * All global scope variables begin with "g_" for global. - * All static file scoped variables begin with "s_" for static. - * Zero terminated strings generally start with "sz" for "string followed by zero." - * integers that hold string or data lengths generally start with "cb" for "count of bytes." - * Also, please to not reformat braces ;-) - * -MLW - */ -#if HAVE_MSESSION -#ifdef HAVE_PHP_SESSION -#ifdef HAVE_PHP_SESSION_CREATESID -/* If the PHP Session module is compiled or available, include support */ -PS_FUNCS_SID(msession); -ps_module ps_mod_msession = { -	PS_MOD_SID(msession) -}; -#else -PS_FUNCS(msession); -ps_module ps_mod_msession = { -	PS_MOD(msession) -}; -#endif -#endif - -/* Per-process variables need by msession */ -static char	s_szdefhost[]="localhost"; -static char *	s_szhost=s_szdefhost; -static int	s_port=8086; -static void *	s_conn=NULL; -static REQB *	s_reqb=NULL; - -zend_function_entry msession_functions[] = { -	PHP_FE(msession_connect,NULL) -	PHP_FE(msession_disconnect,NULL) -	PHP_FE(msession_lock,NULL) -	PHP_FE(msession_unlock,NULL) -	PHP_FE(msession_count,NULL) -	PHP_FE(msession_create,NULL) -	PHP_FE(msession_destroy,NULL) -	PHP_FE(msession_set,NULL) -	PHP_FE(msession_get,NULL) -	PHP_FE(msession_find,NULL) -	PHP_FE(msession_get_array,NULL) -	PHP_FE(msession_set_array,NULL) -	PHP_FE(msession_timeout,NULL) -	PHP_FE(msession_inc,NULL) -	PHP_FE(msession_set_data,NULL) -	PHP_FE(msession_get_data,NULL) -	PHP_FE(msession_listvar,NULL) -	PHP_FE(msession_list,NULL) -	PHP_FE(msession_uniq,NULL) -	PHP_FE(msession_randstr,NULL) -	PHP_FE(msession_plugin,NULL) -	PHP_FE(msession_call,NULL) -	PHP_FE(msession_ctl,NULL) -	PHP_FE(msession_exec,NULL) -	PHP_FE(msession_ping,NULL) -	{NULL, NULL, NULL} -}; - -zend_module_entry msession_module_entry = { -#ifdef PHP_4_1 -	STANDARD_MODULE_HEADER, -#endif -	"msession", -	msession_functions, -	PHP_MINIT(msession), -	NULL, -	NULL, -	NULL, -	PHP_MINFO(msession), -#ifdef PHP_4_1 -	NO_VERSION_YET, -#endif -	STANDARD_MODULE_PROPERTIES -}; - -#ifdef COMPILE_DL_MSESSION -ZEND_GET_MODULE(msession) -#endif - -PHP_MINIT_FUNCTION(msession) -{ -	s_conn = NULL; -	s_szhost = s_szdefhost; -	 -#ifdef HAVE_PHP_SESSION -	php_session_register_module(&ps_mod_msession); -#endif -	return SUCCESS; -} - -PHP_MINFO_FUNCTION(msession) -{ -	php_info_print_table_start(); -	php_info_print_table_header(2, "msession support", "enabled"); -	php_info_print_table_end(); -} -#define RPT_CONN_ERR -#ifdef ERR_DEBUG -#undef RPT_CONN_ERR -#define RPT_CONN_ERR if(s_reqb->req.stat == REQ_ERR && (result == REQE_BADCONN || result == REQE_NOSEND)) \ -		ELOG("Socket reports closed");							\ -	else if(s_reqb->req.stat == REQ_ERR)\ -		ELOG("MSession call failed");\ -#else -#endif - -#define CONN_ERR(reqb)\ -	(reqb->req.stat == REQ_ERR) && (reqb->req.param == REQE_BADCONN || reqb->req.param == REQE_NOSEND) - -int PHPExecRequest(int req, char *session, char *d1, char *d2,int param) -{ -	int result; -	FormatRequest(&s_reqb, req, session, d1, d2, param); -	result = DoRequest(s_conn, &s_reqb); - -	/* Server closed the connection! */ -	if(CONN_ERR(s_reqb)) -	{ -		ELOG("Connection was closed by server"); -		if(ReopenReqConn(s_conn)) -		{ -			FormatRequest(&s_reqb, req, session, d1, d2, param); -			result = DoRequest(s_conn, &s_reqb); -		} -	} -	RPT_CONN_ERR -	return result; -} -int PHPExecRequestMulti(int req, char *session, int n, char **pairs, int param) -{ -	int result; -	FormatRequestMulti(&s_reqb, req, session, n, pairs, param); -	result = DoRequest(s_conn, &s_reqb); - -	/* Server closed the connection! */ -	if(CONN_ERR(s_reqb)) -	{ -		ELOG("Connection was closed by server"); -		if(ReopenReqConn(s_conn)) -		{ -			FormatRequestMulti(&s_reqb, req, session, n, pairs, param); -			result = DoRequest(s_conn, &s_reqb); -		} -	} -	RPT_CONN_ERR -	return result; -} -int PHPExecRequestStrings(int req, char *session, int n, char **strings) -{ -	int result; -	FormatRequestStrings(&s_reqb, req, session, n, strings); -	result = DoRequest(s_conn, &s_reqb); -	/* Server closed the connection! */ -	if(CONN_ERR(s_reqb)) -	{ -		ELOG("Connection was closed by server"); -		if(ReopenReqConn(s_conn)) -		{ -			FormatRequestStrings(&s_reqb, req, session, n, strings); -			result = DoRequest(s_conn, &s_reqb); -		} -	} -	RPT_CONN_ERR -	return result; -} - - -int PHPMsessionConnect(const char *szhost, int nport) -{ -	int fNewHost=FALSE; -	 -	if(!s_reqb) -		s_reqb = AllocateRequestBuffer(2048); - -	if(!s_reqb) /* no buffer, it won't work! */ -		return 0; -	 -	if(strcmp(s_szhost, szhost)) -	{ -		if(s_szhost != s_szdefhost) -			free(s_szhost); -		s_szhost = strdup(szhost); -		fNewHost = TRUE; -	} -	if(nport && nport != s_port) -	{ -		fNewHost = TRUE; -		s_port = nport; -	} - -	ELOG("PHPMsessionConnect:new"); -	if(s_conn && fNewHost) -	{ -		ELOG("Closing old connection, opening new"); -		CloseReqConn(s_conn); -		s_conn = NULL; -	} -	if(!s_conn) -		s_conn = OpenReqConn(s_szhost, s_port); -#ifdef ERR_DEBUG -	else -	{ -		ELOG("Reusing old connection"); -	} -#endif - - -#ifdef ERR_DEBUG -{ -	char buffer[256]; -	sprintf(buffer,"Connect: %s [%d] = %d (%X)\n",  -		s_szhost, s_port, (s_conn != NULL), (unsigned)s_conn); -	php_log_err(buffer); -} -#endif -	return (s_conn) ? 1 : 0; -} - -void PHPMsessionDisconnect() -{ -} - -char *PHPMsessionGetData(char *session TSRMLS_DC) -{ -	char *ret = NULL; -	ELOG("PHPMsessionGetData"); - -	IFCONNECT_BEGIN - -	PHPExecRequest(REQ_DATAGET, (char *)session,"","",0); - -	if(s_reqb->req.stat==REQ_OK) -		ret = safe_estrdup(s_reqb->req.datum); -	IFCONNECT_ENDVAL(0) -	 -	return ret; -} -int PHPMsessionSetData(char *session, char *data TSRMLS_DC) -{ -	ELOG("PHPMsessionSetData"); -	IFCONNECT_BEGIN -	int ret=0; - -	PHPExecRequest(REQ_DATASET, session,"",data,0); -	ret = (s_reqb->req.stat==REQ_OK); -	if(s_reqb->req.stat!=REQ_OK) -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); - -	return ret; - -	IFCONNECT_ENDVAL(0) -} -int PHPMsessionDestroy(char *session TSRMLS_DC) -{ -	ELOG("PHPMsessionDestroy"); -	IFCONNECT_BEGIN - -	int ret=0; -	PHPExecRequest( REQ_DROP, session, "","",0); -	ret = (s_reqb->req.stat==REQ_OK); -	if(s_reqb->req.stat!=REQ_OK) -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -	return ret; -	 -	IFCONNECT_ENDVAL(0) -} - -/* {{{ proto bool msession_connect(string host, string port) -	 Connect to msession sever */ -PHP_FUNCTION(msession_connect) -{ -	char *szhost; -	int nport; -	 -	zval **zhost; -	zval **zport; -	 -	if(ZEND_NUM_ARGS() != 2 || zend_get_parameters_ex(2, &zhost, &zport) == FAILURE) -	{ -		WRONG_PARAM_COUNT; -	} -	 -	convert_to_string_ex(zhost); -	convert_to_string_ex(zport); - -	szhost = Z_STRVAL_PP(zhost); -	nport = atoi(Z_STRVAL_PP(zport)); - -	if(PHPMsessionConnect(szhost,nport)) -	{ -		RETURN_TRUE; -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "MSession connect failed"); -		RETURN_FALSE; -	} -} -/* }}} */ - -/* {{{ proto void msession_disconnect(void) -   Disconnect from msession server */ -PHP_FUNCTION(msession_disconnect) -{ -	PHPMsessionDisconnect(); -	RETURN_NULL(); -} -/* }}} */ - -/* {{{ proto int msession_count(void) -   Get session count */ -PHP_FUNCTION(msession_count) -{ -	IFCONNECT_BEGIN - -	int count; -	PHPExecRequest( REQ_COUNT, "", "","",0); -	 -	count = (s_reqb->req.stat == REQ_OK) ? s_reqb->req.param : 0; - -	RETURN_LONG(count); - -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto bool msession_create(string session) -   Create a session */ -PHP_FUNCTION(msession_create) -{ -	IFCONNECT_BEGIN -/* 	int stat; */ -	char *szsession; -	zval **session; -	 -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &session) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	szsession = Z_STRVAL_PP(session); -	PHPExecRequest( REQ_CREATE, szsession, "","",0); -	if(s_reqb->req.stat==REQ_OK) -	{ -		RETURN_TRUE; -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto bool msession_destroy(string name) -   Destroy a session */ -PHP_FUNCTION(msession_destroy) -{ -	char *szsession; -	zval **session; -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &session) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	szsession = Z_STRVAL_PP(session); -	PHPMsessionDestroy(szsession TSRMLS_CC); - -	RETURN_TRUE; -} -/* }}} */ - -/* {{{ proto int msession_lock(string name) -   Lock a session */ -PHP_FUNCTION(msession_lock) -{ -	IFCONNECT_BEGIN -	char *szsession; -	zval **session; -	 -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &session) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	szsession = Z_STRVAL_PP(session); -	PHPExecRequest( REQ_SLOCK, szsession, "","",0); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		RETURN_LONG(s_reqb->req.param); -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -	} - -	IFCONNECT_END - -} -/* }}} */ -/* {{{ proto int msession_ctl(string name) -   Lock a session */ -PHP_FUNCTION(msession_ctl) -{ -	static char *parray[] = -	{	"EXIST", -		"TTL", -		"AGE", -		"TLA", -		"CTIME", -		"TOUCH", -		"NOW", -		NULL -	}; -	IFCONNECT_BEGIN -	char *szsession; -	zval **session; -	zval **which; -	int fn = REQ_STAT_EXIST; -	 -			 -	int n = ZEND_NUM_ARGS(); - -	if(n != 1 && n != 2) - 	{ -		WRONG_PARAM_COUNT; -	} - -	if(zend_get_parameters_ex(n,&session,&which) == FAILURE) -	{ -		WRONG_PARAM_COUNT; -	} - -	convert_to_string_ex(session); -	szsession = Z_STRVAL_PP(session); - -	if(n > 1) -	{ -		char *szwhich; -		int i; -		convert_to_string_ex(which); -		szwhich = Z_STRVAL_PP(which); -		for(i=0; parray[i]; i++) -		{ -			if(strcasecmp(parray[i], szwhich) == 0) -			{ -				ELOG(szwhich); -				 -				fn = i; -				break; -			} -		} -	} - -	PHPExecRequest( REQ_CTL, szsession, "","",fn); - -	if(s_reqb->req.stat==REQ_OK) -	{ -#ifdef ERR_DEBUG -		char buffer[128]; -		sprintf(buffer, "ret:%s", s_reqb->req.datum); -		ELOG(buffer); -#endif -		s_reqb->req.param = atoi(s_reqb->req.datum); -		RETURN_LONG(s_reqb->req.param); -	} -	else -	{ -		ELOG("msession_ctl failed"); -		RETURN_FALSE; -	} -	IFCONNECT_END -} - -/* {{{ proto int msession_unlock(string session, int key) -   Unlock a session */ -PHP_FUNCTION(msession_unlock) -{ -	IFCONNECT_BEGIN -	char *szsession; -	long lkey; -	zval **session; -	zval **key; -	 -	if(ZEND_NUM_ARGS() != 2 || zend_get_parameters_ex(2, &session, &key) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	szsession = Z_STRVAL_PP(session); -	convert_to_long_ex(key); -	lkey = Z_LVAL_PP(key); -	PHPExecRequest( REQ_SUNLOCK, szsession, "","",lkey); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		RETURN_LONG(s_reqb->req.param); -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto bool msession_set(string session, string name, string value) -   Set value in session */ -PHP_FUNCTION(msession_set) -{ -	IFCONNECT_BEGIN - -	char *szsession; -	char *szname; -	char *szvalue; -	zval **session; -	zval **name; -	zval **value; -	 -	if(ZEND_NUM_ARGS() != 3 || zend_get_parameters_ex(3,&session,&name,&value) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	convert_to_string_ex(name); -	convert_to_string_ex(value); - -	szsession = Z_STRVAL_PP(session); -	szname = Z_STRVAL_PP(name); -	szvalue = Z_STRVAL_PP(value); - -	PHPExecRequest( REQ_SETVAL, szsession, szname, szvalue, 0); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		RETURN_TRUE; -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto string msession_get(string session, string name, string default_value) -   Get value from session */ -PHP_FUNCTION(msession_get) -{ -	IFCONNECT_BEGIN -	char *szsession; -	char *szname; -	char *szvalue; -	zval **session; -	zval **name; -	zval **value; -	 -	if(ZEND_NUM_ARGS() != 3 || zend_get_parameters_ex(3,&session,&name,&value) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	convert_to_string_ex(name); -	convert_to_string_ex(value); -	szsession = Z_STRVAL_PP(session); -	szname = Z_STRVAL_PP(name); -	szvalue = Z_STRVAL_PP(value); - -	PHPExecRequest( REQ_GETVAL, szsession, szname, szvalue,0); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		szvalue = safe_estrdup(s_reqb->req.datum); -		RETURN_STRING(szvalue, 0) -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto string msession_uniq(int num_chars) -   Get uniq id */ -PHP_FUNCTION(msession_uniq) -{ -	IFCONNECT_BEGIN - -	long val; -	zval **param; -	 -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1,¶m) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_long_ex(param); -	val = Z_LVAL_PP(param); - -	PHPExecRequest( REQ_UNIQ,"", "", "",val); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		char *szval = safe_estrdup(s_reqb->req.datum); -		RETURN_STRING(szval, 0) -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END - -} -/* }}} */ - -/* {{{ proto string msession_randstr(int num_chars) -   Get random string */ -PHP_FUNCTION(msession_randstr) -{ -	IFCONNECT_BEGIN -	long val; -	zval **param; -	 -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1,¶m) == FAILURE) -	{ -			WRONG_PARAM_COUNT; -	} -	convert_to_long_ex(param); -	val = Z_LVAL_PP(param); - -	PHPExecRequest( REQ_RANDSTR,"", "", "",val); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		char *szval = safe_estrdup(s_reqb->req.datum); -		RETURN_STRING(szval, 0) -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto array msession_find(string name, string value) -   Find all sessions with name and value */ -PHP_FUNCTION(msession_find) -{ -	IFCONNECT_BEGIN - -	char *szname; -	char *szvalue; -	zval **name; -	zval **value; -	 -	if(ZEND_NUM_ARGS() != 2 || zend_get_parameters_ex(2, &name, &value) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(name); -	convert_to_string_ex(value); -	szname = Z_STRVAL_PP(name); -	szvalue = Z_STRVAL_PP(value); - -	PHPExecRequest( REQ_FIND, "", szname, szvalue,0); - -	if(s_reqb->req.stat==REQ_OK && s_reqb->req.param) -	{ -		int i; -		char *str = s_reqb->req.datum; -		array_init(return_value); - -		for(i=0; i < s_reqb->req.param; i++) -		{ -			int cbstr = strlen(str); -			char *data = safe_estrdup(str); -			add_index_string(return_value, i, data, 0); -			str += (cbstr+1); -		} -	} -	else if(s_reqb->req.stat != REQ_OK) -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto array msession_list(void) -   List all sessions  */ -PHP_FUNCTION(msession_list) -{ -	IFCONNECT_BEGIN -	PHPExecRequest( REQ_LIST, "", "", "",0); - -	if(s_reqb->req.stat==REQ_OK && s_reqb->req.param) -	{ -		int i; -		char *str = s_reqb->req.datum; -		array_init(return_value); - -		for(i=0; i < s_reqb->req.param; i++) -		{ -			int cbstr = strlen(str); -			char *data = safe_estrdup(str); -			add_index_string(return_value, i, data, 0); -			str += (cbstr+1); -		} -	} -	else if(s_reqb->req.stat != REQ_OK) -	{ -		/* May this should be an error? */ -		if(s_reqb->req.param !=  REQE_NOSESSION)  -			php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto array msession_get_array(string session) -   Get array of msession variables  */ -PHP_FUNCTION(msession_get_array) -{ -	IFCONNECT_BEGIN -	char *szsession; -	zval **session; -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &session) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -  } -	convert_to_string_ex(session); -	szsession = Z_STRVAL_PP(session); -	PHPExecRequest( REQ_GETALL, szsession, "", "",0); - -	array_init(return_value); - -	if(s_reqb->req.stat == REQ_OK) -	{ -		int i; -		char *str = s_reqb->req.datum; -		int num = s_reqb->req.param*2; - -		for(i=0; i < num; i+=2) -		{ -			int cbvalue; -			int cbname; -			char *szvalue; -			char *szname; - -			cbname = strlen(str); -			szname = safe_estrndup(str,cbname); -			str += (cbname+1); - -			cbvalue = strlen(str); -			szvalue = safe_estrndup(str,cbvalue); -			str += (cbvalue+1); -			add_assoc_string(return_value, szname, szvalue, 0); -		} -	} -	else -	{ -		if(s_reqb->req.param !=  REQE_NOSESSION) -			php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto bool msession_set_array(string session, array tuples) -   Set msession variables from an array*/ -PHP_FUNCTION(msession_set_array) -{ -	IFCONNECT_BEGIN -	zval **session; -	zval **tuples; -	HashPosition pos; -	zval **entry; -	char *key; -#ifdef PHP_4_1 -	uint keylen; -#endif -#ifdef PHP_4_0 -	ulong keylen; -#endif -	ulong numndx; -	int ndx=0; -	char **pairs; -	HashTable *htTuples; -	int i; -	 -	int countpair;  -	 -	if(ZEND_NUM_ARGS() != 2 || zend_get_parameters_ex(2, &session, &tuples) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	htTuples = Z_ARRVAL_PP(tuples); - -	countpair = zend_hash_num_elements(htTuples); - -	pairs = (char **)safe_emalloc(sizeof(char *), countpair * 2, 0); - -	ELOG("have pairs"); - -	/* Initializes pos */ -	zend_hash_internal_pointer_reset_ex(htTuples, &pos); - -	ELOG("reset pointer"); - -	for(i=0; i < countpair; i++) -	{ -		if(zend_hash_get_current_data_ex(htTuples, (void **)&entry, &pos) != SUCCESS)  -			break; - -		if(entry) -		{ -			char *szentry; -			convert_to_string_ex(entry); -			szentry = Z_STRVAL_PP(entry); -			 -       			if(zend_hash_get_current_key_ex(htTuples,&key,&keylen,&numndx,0,&pos)== HASH_KEY_IS_STRING) -			{ -#ifdef ERR_DEBUG -{ -				char buffer [256]; -				sprintf(buffer, "%s=%s\n", key, szentry); -				ELOG(buffer); -} -#endif -				pairs[ndx++] = key; -				pairs[ndx++] = szentry; -			} -		} -		zend_hash_move_forward_ex(htTuples, &pos); -	} - -	PHPExecRequestMulti(REQ_SETVAL, Z_STRVAL_PP(session), countpair, pairs,0); - -	if(s_reqb->req.stat != REQ_OK) -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -	efree((void *)pairs); -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto array msession_listvar(string name) -   return associative array of value:session for all sessions with a variable named 'name' */ -PHP_FUNCTION(msession_listvar) -{ -	IFCONNECT_BEGIN -	zval **name; -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &name) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(name); -	PHPExecRequest( REQ_LISTVAR, "", Z_STRVAL_PP(name), "",0); - -	array_init(return_value); - -	if(s_reqb->req.stat == REQ_OK) -	{ -		int i; -		char *str = s_reqb->req.datum; -		int num = s_reqb->req.param*2; - -		for(i=0; i < num; i+=2) -		{ -			int cbvalue; -			int cbname; -			char *szvalue; -			char *szname; - -			cbname= strlen(str); -			szname= safe_estrndup(str,cbname); -			str += (cbname+1); - -			cbvalue = strlen(str); -			szvalue = safe_estrndup(str,cbvalue); -			str += (cbvalue+1); -			add_assoc_string(return_value, szname, szvalue, 0); -		} -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto int msession_timeout(string session [, int param ]) -   Set/get session timeout */ -PHP_FUNCTION(msession_timeout) -{ -	IFCONNECT_BEGIN -	zval **session; -	int ac = ZEND_NUM_ARGS(); -	int zstat = FAILURE; -	int timeout = 0; -	if(ac == 1) -	{ -		zstat = zend_get_parameters_ex(1, &session); -	} -	else if(ac == 2) -	{ -		zval **param; -		zstat = zend_get_parameters_ex(2, &session, ¶m); -		convert_to_long_ex(param); -		timeout = Z_LVAL_PP(param); -	} -	if(zstat == FAILURE) -	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	PHPExecRequest( REQ_TIMEOUT, Z_STRVAL_PP(session), "","",timeout); - -	if(s_reqb->req.stat == REQ_OK) -	{ -		RETURN_LONG( s_reqb->req.param); -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto string msession_inc(string session, string name)  -   Increment value in session */ -PHP_FUNCTION(msession_inc) -{ -	IFCONNECT_BEGIN -	char *val; -	zval **session; -	zval **name; -	 -	if(ZEND_NUM_ARGS() != 2 || zend_get_parameters_ex(2, &session, &name) == FAILURE) -	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	convert_to_string_ex(name); - -	PHPExecRequest( REQ_INC, Z_STRVAL_PP(session), Z_STRVAL_PP(name),0,0); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		val = safe_estrdup(s_reqb->req.datum); -		RETURN_STRING(val, 0) -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto string msession_get_data(string session) -   Get data session unstructured data. (PHP sessions use this)  */ -PHP_FUNCTION(msession_get_data) -{ -	IFCONNECT_BEGIN -	char *val; -	zval **session; -	 -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &session) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); - -	val = PHPMsessionGetData(Z_STRVAL_PP(session) TSRMLS_CC); - -	if(val) -	{ -		RETURN_STRING(val, 0) -	} -	else -	{ -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto bool msession_set_data(string session, string value) -   Set data session unstructured data. (PHP sessions use this)  */ -PHP_FUNCTION(msession_set_data) -{ -	IFCONNECT_BEGIN -	zval **session; -	zval **value; -	 -	if(ZEND_NUM_ARGS() != 2 || zend_get_parameters_ex(2, &session, &value) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	convert_to_string_ex(value); - -	if(PHPMsessionSetData(Z_STRVAL_PP(session), Z_STRVAL_PP(value) TSRMLS_CC)) -	{ -		RETURN_TRUE; -	} -	else -	{ -		RETURN_FALSE; -	} -	IFCONNECT_END -} -/* }}} */ - -/* {{{ proto string msession_plugin(string session, string val [, string param ]) -   Call the personality plugin escape function */ -PHP_FUNCTION(msession_plugin) -{ -	IFCONNECT_BEGIN -	int ret; -	char *retval; -	zval **session; -	zval **val; -	zval **param=NULL; -	 -	if(ZEND_NUM_ARGS() == 3) -	{ -		ret = zend_get_parameters_ex(3, &session, &val, ¶m); -		convert_to_string_ex(param); -	} -	else if(ZEND_NUM_ARGS() == 2) -	{ -		ret = zend_get_parameters_ex(2, &session, &val); -	} -	else - 	{ -		WRONG_PARAM_COUNT; -	} -	if(ret == FAILURE) -	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(session); -	convert_to_string_ex(val); - -	ret = atoi(Z_STRVAL_PP(val)); - -	PHPExecRequest( REQ_PLUGIN, Z_STRVAL_PP(session), Z_STRVAL_PP(val), param ? Z_STRVAL_PP(param) : "",ret); - -	if(s_reqb->req.stat==REQ_OK && s_reqb->req.len) -	{ -		retval = safe_estrdup(s_reqb->req.datum); -		RETURN_STRING(retval, 0) -	} -	else if(s_reqb->req.stat != REQ_OK) -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -		 -	} -	IFCONNECT_END -} -/* }}} */ -#define MAX_EXT_VAL	5 -/* {{{ proto string msession_call(string fn_name, [, string param1 ], ... [,string param4]) -   Call the plugin function named fn_name */ -PHP_FUNCTION(msession_call) -{ -	IFCONNECT_BEGIN -	int n; -	int i; -	int ret; -	char *retval; -	zval **val[MAX_EXT_VAL]; -	char *strings[MAX_EXT_VAL+1]; -/* 	zval **param=NULL; */ -	 -	n = ZEND_NUM_ARGS(); - -	if((n < 1) || (n > MAX_EXT_VAL)) - 	{ -		WRONG_PARAM_COUNT; -	} - -	ret = zend_get_parameters_ex(ZEND_NUM_ARGS(), &val[0],&val[1],&val[2],&val[3],&val[4]); - -	if(ret == FAILURE) -	{ -		WRONG_PARAM_COUNT; -	} -	for(i=0; i < n; i++) -	{ -		convert_to_string_ex(val[i]); -		strings[i] = Z_STRVAL_PP(val[i]); -	} - -	PHPExecRequestStrings(REQ_CALL, NULL , n, strings); - -	if(s_reqb->req.stat==REQ_OK && s_reqb->req.len) -	{ -		retval = safe_estrdup(s_reqb->req.datum); -		RETURN_STRING(retval, 0) -	} -	else if(s_reqb->req.stat != REQ_OK) -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -	} -	IFCONNECT_END -} -/* }}} */ -/* {{{ proto string msession_exec(string cmdline) -   executes a program on msession system  */ -PHP_FUNCTION(msession_exec) -{ -	IFCONNECT_BEGIN -	char *val; -	zval **cmdline; -	 -	if(ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &cmdline) == FAILURE) - 	{ -		WRONG_PARAM_COUNT; -	} -	convert_to_string_ex(cmdline); - -	PHPExecRequest( REQ_EXEC, Z_STRVAL_PP(cmdline), "","",0); - -	if(s_reqb->req.stat == REQ_OK) -	{ -		val = safe_estrdup(s_reqb->req.datum); -		RETURN_STRING(val, 0) -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_NULL(); -	} -	IFCONNECT_END -} -/* }}} */ -/* {{{ proto bool msession_ping(void) -   returns non-zero if msession is alive*/ -PHP_FUNCTION(msession_ping) -{ -	IFCONNECT_BEGIN - -	PHPExecRequest(REQ_PING,"","","", 0); - -	if(s_reqb->req.stat==REQ_OK) -	{ -		RETURN_TRUE; -	} -	else -	{ -		php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		RETURN_FALSE; -	} -	IFCONNECT_END -} -/* }}} */ - -#ifdef HAVE_PHP_SESSION - -PS_OPEN_FUNC(msession) -{ -	int port; -	int len = strlen(save_path)+1; -	char * path = emalloc(len); -	char * szport; - -	strcpy(path, save_path); - -	szport = strchr(path, ':'); - -	if(szport) -	{ -		*szport++=0; -		port = atoi(szport); -	} -	else -	{ -		port = s_port; -	} -	 -	ELOG( "ps_open_msession"); -	PS_SET_MOD_DATA((void *)1); /* session.c needs a non-zero here! */ -	if (PHPMsessionConnect(path, port)) { -		efree(path); -		return SUCCESS; -	} else { -		efree(path); -		return FAILURE; -	} -} - -PS_CLOSE_FUNC(msession) -{ -	ELOG( "ps_close_msession"); -	PHPMsessionDisconnect(); -	return SUCCESS; -} - -PS_READ_FUNC(msession) -{ -	ELOG( "ps_read_msession"); -	*val = PHPMsessionGetData((char *)key TSRMLS_CC); -	if(*val) -		{ -			*vallen = strlen(*val); -		} -	else -	{ -		*val = emalloc(1); -		**val=0; -		*vallen = 0; -	} -	return SUCCESS; -} - -PS_WRITE_FUNC(msession) -{ -	ELOG( "ps_write_msession"); -	return (PHPMsessionSetData((char *)key, (char *)val TSRMLS_CC)) ? SUCCESS : FAILURE; -} - -PS_DESTROY_FUNC(msession) -{ -	ELOG( "ps_destroy_msession"); -	return (PHPMsessionDestroy((char *)key TSRMLS_CC)) ? SUCCESS : FAILURE; -} - -PS_GC_FUNC(msession) -{ -	ELOG( "ps_gc_msession"); -	return SUCCESS; -} - -#ifdef HAVE_PHP_SESSION_CREATESID -PS_CREATE_SID_FUNC(msession) -{ -	if(s_reqb && s_conn)  -	{ -		ELOG("Should create a new session"); -		PHPExecRequest( REQ_UNIQ,"", "", "",SID_LEN); - -		if(s_reqb->req.stat==REQ_OK) -		{ -			ELOG("Reports UNIQ success"); -			if(newlen) -				*newlen = SID_LEN; -			return safe_estrdup(s_reqb->req.datum); -		} -		else -		{ -			ELOG("Reports that UNIQ failed"); -			php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", ReqbErr(s_reqb)); -		} -	} -	ELOG("Yikes, could not get sid from msession 2003"); -	return php_session_create_id(mod_data, newlen TSRMLS_CC); -} -#endif  /* HAVE_PHP_SESSION_CREATESID */ -#endif	/* HAVE_PHP_SESSION */ -#endif	/* HAVE_MSESSION */ - diff --git a/ext/msession/msession.php b/ext/msession/msession.php deleted file mode 100644 index 4eb9d9b6cd..0000000000 --- a/ext/msession/msession.php +++ /dev/null @@ -1,10 +0,0 @@ -<? -$module = 'msession'; -$function = 'confirm_' . $module . '_compiled'; -if (extension_loaded($module)) { -	$str = $function($module); -} else { -	$str = "Module $module is not compiled into PHP"; -} -echo "$str\n"; -?> diff --git a/ext/msession/php_msession.h b/ext/msession/php_msession.h deleted file mode 100644 index b41df742f6..0000000000 --- a/ext/msession/php_msession.h +++ /dev/null @@ -1,106 +0,0 @@ -/* -   +----------------------------------------------------------------------+ -   | msession 1.0                                                         | -   +----------------------------------------------------------------------+ -   | Copyright (c) 1997-2006 The PHP Group                                | -   +----------------------------------------------------------------------+ -   | This source file is subject to version 3.01 of the PHP license,      | -   | that is bundled with this package in the file LICENSE, and is        | -   | available through the world-wide-web at the following url:           | -   | http://www.php.net/license/3_01.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: Mark Woodward <markw@mohawksoft.com>                        | -   |    Portions copyright the PHP group.                                 | -   +----------------------------------------------------------------------+ - */ - -#ifndef PHP_MSESSION_H -#define PHP_MSESSION_H - -/* You should tweak config.m4 so this symbol (or some else suitable) -   gets defined. -*/ -#if HAVE_MSESSION - -extern zend_module_entry msession_module_entry; -#define phpext_msession_ptr &msession_module_entry - -#ifdef PHP_WIN32 -#define PHP_MSESSION_API __declspec(dllexport) -#else -#define PHP_MSESSION_API -#endif - -PHP_MINIT_FUNCTION(msession); -PHP_MINFO_FUNCTION(msession); - -PHP_FUNCTION(msession_connect); -PHP_FUNCTION(msession_disconnect); -PHP_FUNCTION(msession_lock); -PHP_FUNCTION(msession_unlock); -PHP_FUNCTION(msession_ctl); -PHP_FUNCTION(msession_count); -PHP_FUNCTION(msession_create); -PHP_FUNCTION(msession_destroy); -PHP_FUNCTION(msession_exec); -PHP_FUNCTION(msession_set); -PHP_FUNCTION(msession_get); -PHP_FUNCTION(msession_find); -PHP_FUNCTION(msession_get_array); -PHP_FUNCTION(msession_set_array); -PHP_FUNCTION(msession_timeout); -PHP_FUNCTION(msession_inc); -PHP_FUNCTION(msession_set_data); -PHP_FUNCTION(msession_get_data); -PHP_FUNCTION(msession_listvar); -PHP_FUNCTION(msession_list); -PHP_FUNCTION(msession_uniq); -PHP_FUNCTION(msession_randstr); -PHP_FUNCTION(msession_plugin); -PHP_FUNCTION(msession_call); -PHP_FUNCTION(msession_ping); - -/*  -  	Declare any global variables you may need between the BEGIN -	and END macros here:      - -ZEND_BEGIN_MODULE_GLOBALS(msession) -	int global_variable; -	void *conn; -	char *host; -ZEND_END_MODULE_GLOBALS(msession) - -*/ -/* In every function that needs to use variables in php_msession_globals, -   do call MSESSIONLS_FETCH(); after declaring other variables used by -   that function, and always refer to them as MSESSIONG(variable). -   You are encouraged to rename these macros something shorter, see -   examples in any other php module directory. -*/ - -#ifdef ZTS -#define MSESSIONG(v) (msession_globals->v) -#define MSESSIONLS_FETCH() php_msession_globals *msession_globals = ts_resource(msession_globals_id) -#else -#define MSESSIONG(v) (msession_globals.v) -#define MSESSIONLS_FETCH() -#endif - -#else - -#define phpext_msession_ptr NULL - -#endif - -#endif	/* PHP_MSESSION_H */ - - -/* - * Local variables: - * tab-width: 4 - * c-basic-offset: 4 - * End: - */ diff --git a/ext/msession/reqclient.h b/ext/msession/reqclient.h deleted file mode 100644 index c8ff1c979b..0000000000 --- a/ext/msession/reqclient.h +++ /dev/null @@ -1,171 +0,0 @@ -/* -   +----------------------------------------------------------------------+ -   | msession 1.0                                                         | -   +----------------------------------------------------------------------+ -   | Copyright (c) 1997-2006 The PHP Group                                | -   +----------------------------------------------------------------------+ -   | This source file is subject to version 3.01 of the PHP license,      | -   | that is bundled with this package in the file LICENSE, and is        | -   | available through the world-wide-web at the following url:           | -   | http://www.php.net/license/3_01.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: Mark Woodward <markw@mohawksoft.com>                        | -   |    Portions copyright the PHP group.                                 | -   +----------------------------------------------------------------------+ - */ - -/* --------------------------------------------------------------------------- -	These are definitions are pulled from Phoenix. - 	It would probably be easier to maintain one file,  -	but some phoenix header files conflict with other -	project header files common to PHP. Besides, this -	allows this header to be PHP license and Phoenix to -	be LGPL with no conflicts. - -	MAKE NO CHANGES TO THIS FILE IT. MUST REMAIN CONSTANT -	WITH PHOENIX OR IT WILL NOT WORK. --------------------------------------------------------------------------- -*/ -/* Required to use the new version of Phoenix 1.2 */ - -#ifndef REQCLIENT_VER	 -#define REQCLIENT_VER 030113 -#endif - -enum REQ_TYPES -{ -	REQ_ERR, -	REQ_OK, -	REQ_CTL, -	REQ_SETVAL, -	REQ_GETVAL, -	REQ_CREATE, -	REQ_DROP, -	REQ_GETALL, -	REQ_FIND, -	REQ_COUNT, -	REQ_FLUSH, -	REQ_SLOCK, -	REQ_SUNLOCK, -	REQ_TIMEOUT, -	REQ_INC, -	REQ_DATAGET, -	REQ_DATASET, -	REQ_LIST, -	REQ_LISTVAR, -	REQ_UNIQ, -	REQ_RANDSTR, -	REQ_PLUGIN, -	REQ_CALL, -	REQ_SERIALIZE, -	REQ_RESTORE, -	REQ_EXEC, -	REQ_LAST, -	REQ_INTERNAL_BEGIN=1023, -	REQ_INTERNALLAST, -}; -enum REQ_ERRORS -{ -	REQE_NOERROR=0, -	REQE_NOSESSION, -	REQE_DUPSESSION, -	REQE_NOWLOCK, -	REQE_NOVALUE, -	REQE_LOCKED, -	REQE_NOSEND, -	REQE_NOCONNECT, -	REQE_BADCONN, -	REQE_BADHDR, -	REQE_BADVER, -	REQE_BADLEN, -	REQE_BUFFER, -	REQE_DENIED, -	REQE_NOFN, -	REQE_UNKNOWN -}; - - -#define REQ_POPEN               1024 -#define REQ_PCLOSE              1025 -#define REQ_PING                1026 - -typedef struct _requestPacket -{ -	int	version; -	int	stat; -	int	len; -	int	session; -	int	name; -	int	value; -	int 	param; -	char	datum[0]; -}REQ; - -typedef struct _requestBuf -{ -	unsigned int type;	/* Type of packet, dynamic/static */ -	unsigned int size;	/* size of memory block */ -#if (REQCLIENT_VER >= 030113) -	unsigned int fmt;	/* format, binary/ascii */ -	unsigned int reserved;	/* Just in case */ -#else -#warning You are using an old Phoenix definition, this will have problems with a newer version -#endif -	REQ	req; -}REQB; - -#define MAX_REQ		16384 - -#define REQB_STATIC	1 -#define REQB_DYNAMIC	2 - -#define REQ_STAT_EXIST	0 -#define REQ_STAT_TTL	1	 -#define REQ_STAT_AGE	2 -#define REQ_STAT_TLA	3 -#define REQ_STAT_CTIM	4 -#define REQ_STAT_TOUCH	5 -#define REQ_STAT_NOW	6 - - -#define STATIC_REQB( len )	\ -	char buffer [ len ]; 	\ -	REQB *preq = StaticRequestBuffer(buffer, len); - -#if defined (__cplusplus) -extern "C" { -#endif - -#define SIZEREQB(REQB,SIZE) (((REQB)->size >= (unsigned int) SIZE) ? REQB : SizeRequestBuffer(REQB,SIZE)) -REQB *AllocateRequestBuffer(unsigned size); -void FreeRequestBuffer(REQB *req); -REQB *SizeRequestBuffer(REQB *req, unsigned int size); -REQB *StaticRequestBuffer(char *buffer, unsigned int cb); - -int FormatRequest(REQB **buffer, int stat, const char *session, const char *name, const char *value, int param); -int FormatRequestMulti(REQB **buffer, int stat, char *session, int n, char **pairs, int param); -int FormatRequestStrings(REQB **ppreq, int stat, char *session, int n, char **strings); -int DoSingleRequest(char *hostname, int port, REQB **preq); -void *OpenReqConn(char *hostname, int port); -void CloseReqConn(void *conn); -void DeleteReqConn(void *conn); -unsigned char ReopenReqConn(void *conn); -int DoRequest(void *conn, REQB **preq); -char *ReqbErr(REQB *reqb); - -#define ASSERT_STAT(PREQ) if(PREQ->stat != REQ_OK) \ -	{fprintf(stderr, "Error in Request %s %d %s\n", \ -		__FILE__,__LINE__, ReqErr(PREQ->param)); exit(-1); } - -#if defined (__cplusplus) -	/* C API but with class definitions */ -	int ReadRequestTimeout(REQB **ppreq, MSock *sock, int timeout); -	int ReadRequest(REQB **preq, MSock *sock); -	int WriteRequest(REQB *preq, MSock *sock); -} -#endif - | 
