summaryrefslogtreecommitdiff
path: root/ext/session
diff options
context:
space:
mode:
authorPierre Joye <pajoye@php.net>2010-06-08 22:30:16 +0000
committerPierre Joye <pajoye@php.net>2010-06-08 22:30:16 +0000
commit9e5313fdcaf7257abcccc29b504effa07d08211b (patch)
treed1c967525201b44bb23801d0ffcf73f2bf4c9804 /ext/session
parent32447e490283216637ba174aa754749f2eafd155 (diff)
downloadphp-git-9e5313fdcaf7257abcccc29b504effa07d08211b.tar.gz
- [DOC] MFH: add session.entropy* support to windows
Diffstat (limited to 'ext/session')
-rw-r--r--ext/session/session.c26
1 files changed, 25 insertions, 1 deletions
diff --git a/ext/session/session.c b/ext/session/session.c
index dac8e954b7..fae961f51e 100644
--- a/ext/session/session.c
+++ b/ext/session/session.c
@@ -26,7 +26,8 @@
#include "php.h"
#ifdef PHP_WIN32
-#include "win32/time.h"
+# include "win32/winutil.h"
+# include "win32/time.h"
#else
#include <sys/time.h>
#endif
@@ -402,6 +403,28 @@ PHPAPI char *php_session_create_id(PS_CREATE_SID_ARGS) /* {{{ */
efree(buf);
if (PS(entropy_length) > 0) {
+ unsigned char rbuf[2048];
+
+#ifdef PHP_WIN32
+ size_t toread = PS(entropy_length);
+
+ if (php_win32_get_random_bytes(rbuf, (size_t) toread) == SUCCESS){
+
+ switch (PS(hash_func)) {
+ case PS_HASH_FUNC_MD5:
+ PHP_MD5Update(&md5_context, rbuf, toread);
+ break;
+ case PS_HASH_FUNC_SHA1:
+ PHP_SHA1Update(&sha1_context, rbuf, toread);
+ break;
+# if defined(HAVE_HASH_EXT) && !defined(COMPILE_DL_HASH)
+ case PS_HASH_FUNC_OTHER:
+ PS(hash_ops)->hash_update(hash_context, rbuf, toread);
+ break;
+# endif /* HAVE_HASH_EXT */
+ }
+ }
+#else
int fd;
fd = VCWD_OPEN(PS(entropy_file), O_RDONLY);
@@ -431,6 +454,7 @@ PHPAPI char *php_session_create_id(PS_CREATE_SID_ARGS) /* {{{ */
}
close(fd);
}
+#endif
}
digest = emalloc(digest_len + 1);