From: Admin at hellzoneinc dot com
Operating system: Server 2008
PHP version: 5.2.5
PHP Bug Type: MySQL related
Bug description: Script will not move row from 1 table to another. Works w/
PHP4.
Description:
------------
Well, I am using php-nuke for my website. I've had issues w/ PHP5 before
and have always gone back to PHP4 since it worked. Since the new release
isn't psoted for Windows yet, I must use PHP5. Everything works fine with
the user registration EXCEPT.... When the user clicks the activate link in
their e-mail, it brings them to the page saying it was successful, but it's
wrong. The user info gets entered into the nuke_users_temp table just fine,
however when the activate script runs, it doesn't copy the info over to
nuke_users as it should, but does make it through to the remove that row.
PHP4 works fine with this so I figured it's a PHP5 issue, so hope this
helps.
Reproduce code:
---------------
It's not a visual error, so here goes. Sorry for the numerous lines.
function activate($username, $check_num) {
global $db, $user_prefix, $module_name, $language, $prefix;
$username = filter($username, "nohtml", 1);
$past = time()-86400;
$db->sql_query("DELETE FROM ".$user_prefix."_users_temp WHERE time <
$past");
$sql = "SELECT * FROM ".$user_prefix."_users_temp WHERE
username='$username' AND check_num='$check_num'";
$result = $db->sql_query($sql);
if ($db->sql_numrows($result) == 1) {
$row = $db->sql_fetchrow($result);
$user_password =
htmlspecialchars(stripslashes($row['user_password']));
if ($check_num == $row['check_num']) {
$db->sql_query("INSERT INTO ".$user_prefix."_users
(user_id, username,
user_email, user_password, user_avatar, user_avatar_type, user_regdate,
user_lang) VALUES (NULL, '".$row['username']."', '".$row['user_email']."',
'$user_password', 'gallery/blank.gif', '3', '".$row['user_regdate']."',
'$language')");
$result2 = $db->sql_query("SELECT user_id FROM
".$user_prefix."_users
WHERE username='".$row['username']."'");
$row2 = $db->sql_fetchrow($result2);
$guserid = intval($row2['user_id']);
$db->sql_query("INSERT INTO ".$prefix."_bbgroups
(group_name, group_description, group_single_user, group_moderator) VALUES
('', 'Personal User', '1', '0')");
$group_id = $db->sql_nextid();
$db->sql_query("INSERT INTO
".$prefix."_bbuser_group (user_id, group_id, user_pending) VALUES
('$guserid', '$group_id', '0')");
$db->sql_query("DELETE FROM ".$user_prefix."_users_temp
WHERE
username='$username' AND check_num='$check_num'");
include("header.php");
title(""._ACTIVATIONYES."");
OpenTable();
echo "<center><b>".$row['username'].":</b>
"._ACTMSG."</center>";
CloseTable();
include("footer.php");
die();
} else {
include("header.php");
title(""._ACTIVATIONERROR."");
OpenTable();
echo "<center>"._ACTERROR1."</center>";
CloseTable();
include("footer.php");
die();
}
} else {
include("header.php");
title(""._ACTIVATIONERROR."");
OpenTable();
echo "<center>"._ACTERROR2."</center>";
CloseTable();
include("footer.php");
die();
}
}
Expected result:
----------------
Copy the user from nuke_users_temp to nuke_users and I believe maybe 2
other tables from what I think I'm seeing, then remove that line from
nuke_users_temp.
Actual result:
--------------
Does not copy the user, but then removes them from nuke_users_temp as it
should.
--
Edit bug report at http://bugs.php.net/?id=43937&edit=1
--
Try a CVS snapshot (PHP 4.4):
http://bugs.php.net/fix.php?id=43937&r=trysnapshot44
Try a CVS snapshot (PHP 5.2):
http://bugs.php.net/fix.php?id=43937&r=trysnapshot52
Try a CVS snapshot (PHP 5.3):
http://bugs.php.net/fix.php?id=43937&r=trysnapshot53
Try a CVS snapshot (PHP 6.0):
http://bugs.php.net/fix.php?id=43937&r=trysnapshot60
Fixed in CVS: http://bugs.php.net/fix.php?id=43937&r=fixedcvs
Fixed in release:
http://bugs.php.net/fix.php?id=43937&r=alreadyfixed
Need backtrace: http://bugs.php.net/fix.php?id=43937&r=needtrace
Need Reproduce Script: http://bugs.php.net/fix.php?id=43937&r=needscript
Try newer version: http://bugs.php.net/fix.php?id=43937&r=oldversion
Not developer issue: http://bugs.php.net/fix.php?id=43937&r=support
Expected behavior: http://bugs.php.net/fix.php?id=43937&r=notwrong
Not enough info:
http://bugs.php.net/fix.php?id=43937&r=notenoughinfo
Submitted twice:
http://bugs.php.net/fix.php?id=43937&r=submittedtwice
register_globals: http://bugs.php.net/fix.php?id=43937&r=globals
PHP 3 support discontinued: http://bugs.php.net/fix.php?id=43937&r=php3
Daylight Savings: http://bugs.php.net/fix.php?id=43937&r=dst
IIS Stability: http://bugs.php.net/fix.php?id=43937&r=isapi
Install GNU Sed: http://bugs.php.net/fix.php?id=43937&r=gnused
Floating point limitations: http://bugs.php.net/fix.php?id=43937&r=float
No Zend Extensions: http://bugs.php.net/fix.php?id=43937&r=nozend
MySQL Configuration Error: http://bugs.php.net/fix.php?id=43937&r=mysqlcfg