Log in

View Full Version : Can anyone help with some modcp code?


the3jams
03-19-2004, 06:38 PM
I'm having trouble with some code and was wondering if someone who is more knowledgeable would be able to help? Here is my situation....

I'm trying to give my mods more editing options in their modcp. In /modcp/user.php I have added this code to try and let them edit the join date of users.

// ###################### Start editjoindate #####################
if ($_REQUEST['do'] == 'editjoindate')
{
globalize($_REQUEST, array('userid' => INT));

if (empty($userid))
{
print_stop_message('invalid_user_specified');
}

$noalter = explode(',', $undeletableusers);
if (!empty($noalter[0]) AND in_array($userid, $noalter))
{
print_stop_message('user_is_protected_from_alterat ion_by_undeletableusers_var');
}

$user = $DB_site->query_first("
SELECT * FROM " . TABLE_PREFIX . "user WHERE userid = $userid
");

print_form_header('user','doeditjoindate', 0, 1);
construct_hidden_code('userid', $userid);
print_table_header(construct_phrase($vbphrase['x_y_id_z'], $vbphrase['join_date'], $user['username'], $user['userid']));
print_time_row($vbphrase['join_date'], 'joindate', $user['joindate'], 0);
print_submit_row();

}

// ###################### Start doeditjoindate #######################
if ($_POST['do'] == 'doeditjoindate')
{
globalize($_POST, array('userid' => INT, 'joindate' => STR));

$noalter = explode(',', $undeletableusers);
if (!empty($noalter[0]) AND in_array($userid, $noalter))
{
print_stop_message('user_is_protected_from_alterat ion_by_undeletableusers_var');
}

if (empty($userid))
{
print_stop_message('invalid_user_specified');
}

$DB_site->query("
UPDATE " . TABLE_PREFIX . "user SET
joindate = $joindate
WHERE userid = $userid
");

if (can_moderate(0, 'canviewprofile'))
{
define('CP_REDIRECT', "user.php?do=viewuser&userid=$userid");
}
else
{
define('CP_REDIRECT', "index.php?do=home");
}
print_stop_message('updated_joindate_successfully' );

}
Everything worked fine except that it wont store the changed join date. Instead it sets it to 0. It probably has to do with the print_time_row and the way I'm updating the db, but I can't figure it out. :(

Can anyone help?

Xenon
03-19-2004, 06:47 PM
you have to convert the joindate from the string into a timestamp before you enter it into the DB.

look at admincp/user.php about how they did it :)

the3jams
03-19-2004, 07:36 PM
Thanks for you reply.
This is all I saw in the update routine of admincp/user.php that looked like they were converting the joindate...

require_once('./includes/functions_misc.php');
$user['joindate'] = vbmktime(12, 0, 0, intval($joindate['month']), intval($joindate['day']), intval($joindate['year']));
I don't know if that's what you where referring to but I tried it anyway and it still didn't work. Also where do they actually update the user table? I didn't see any update queries for posts, joindate, etc.

Maybe I'm getting in over my head. For some reason I didn't think vb2's code was this hard for me to figure out :(

Xenon
03-19-2004, 07:58 PM
yes it's this line, but you have to make sure, the formular of your editfield is exaclty like the one in the ACP.

also remove the => STR form the globalize call, as you will get an array, and not a string then :)