Скрипт Проблемы с покупкой фруктов

  • Автор темы BigFruct
  • Дата начала
BigFruct
Участник
Сообщения
12
Реакции
1
Обнаружились проблемы с покупкой фруктов. Например, человек регается на проекте, ему причисляется за регистрацию 3000 серебра. Он покупает на них деревья, заходит в склад, там деревья не то что плодов не несут, так они ещё и не видны! А если добавить пользователю с админки самой вручную например 1000 серебра, так деревья сразу же появляются и начинают нести плоды. Как сделать всё по нормальному?
 
Андрей
Участник
Сообщения
241
Реакции
55
BigFruct написал(а):
Обнаружились проблемы с покупкой фруктов. Например, человек регается на проекте, ему причисляется за регистрацию 3000 серебра. Он покупает на них деревья, заходит в склад, там деревья не то что плодов не несут, так они ещё и не видны! А если добавить пользователю с админки самой вручную например 1000 серебра, так деревья сразу же появляются и начинают нести плоды. Как сделать всё по нормальному?
Скинь файл signup
 
BigFruct
Участник
Сообщения
12
Реакции
1
Скрытое содержимое для зарегистрированных пользователей!

<?PHP
$_OPTIMIZATION["title"] = "Регистрация";
$_OPTIMIZATION["description"] = "Регистрация пользователя в системе";
$_OPTIMIZATION["keywords"] = "Регистрация нового участника в системе";

if(isset($_SESSION["user_id"])){ Header("Location: /account"); return; }


if(!isset($_GET["key"])){


?>
<div class="s-bk-lf">
<div class="acc-title">Регистрация</div>
</div>
<div class="silver-bk"><div class="clr"></div>

<p>Укажите Ваш Email, на него будет выслана ссылка для регистрации.</p>


<?PHP

if(isset($_POST["email"])){

if(isset($_SESSION["captcha"]) AND strtolower($_SESSION["captcha"]) == strtolower($_POST["captcha"])){

unset($_SESSION["captcha"]);

$email = $func->IsMail($_POST["email"]);
$referer_id = (isset($_COOKIE["i"]) AND intval($_COOKIE["i"]) > 0 AND intval($_COOKIE["i"]) < 1000000) ? intval($_COOKIE["i"]) : 1;
$ttime = time();
$tidex = time() - 60*15;

if($email !== false){

$db->Query("DELETE FROM db_regkey WHERE date_del < '".$ttime."' OR (date_add < '".$tidex."' AND email = '$email')");
$db->Query("SELECT COUNT(*) FROM db_regkey WHERE email = '$email'");

if($db->FetchRow() == 0){

$db->Query("SELECT COUNT(*) FROM db_users_a WHERE email = '$email'");

if($db->FetchRow() == 0){


# Узнаем реферера
if($referer_id != 1){

$db->Query("SELECT user FROM db_users_a WHERE id = '$referer_id' LIMIT 1");

if($db->NumRows() > 0){

$referer_name = $db->FetchRow();

}else{ $referer_id = 1; $referer_name = "First"; }

}else{ $referer_id = 1; $referer_name = "First"; }


# Заносим запись в reg_key
$td = $ttime + 60*60;
$db->Query("INSERT INTO db_regkey (email, referer_id, referer_name, date_add, date_del)
VALUES ('$email','$referer_id','$referer_name','$ttime','$td')");

$lid = $db->LastInsert();
$reg_key = $lid."-".md5($lid."_rfs_".$lid);

# Отправляем на почту
$sender = new isender;
$sender -> SendRegKey($email, $reg_key);

echo "<center><font color = 'green'><b>Указанный Email была отправлена ссылка для регистрации</b></font></center>";
?></div>
<div class="clr"></div>
<?PHP
return;

}else echo "<center><font color = 'red'><b>Указанный Email уже зарегистрирован в системе</b></font></center>";

}else echo "<center><font color = 'red'><b>За последние 15 минут Вы уже запрашивали ссылку для регистрации</b></font></center>";

}else echo "<center><font color = 'red'><b>Email имеет неверный формат</b></font></center>";

}else echo "<center><font color = 'red'><b>Символы с картинки введены неверно</b></font></center>";

}
?>
<BR />
<form action="" method="post">
<table width="500" border="0" cellspacing="0" cellpadding="0">
<tr>
<td align="left" width="250">Email (На него вышлем ссылку):</td>
<td align="left" width="250"><input name="email" type="text" size="25" maxlength="50" value="<?=(isset($_POST["email"])) ? $_POST["email"] : false; ?>"/></td>
</tr>
<tr>
<td align="left" width="250" style="padding-top:20px;">
<a href="https://servahoc.ru/redirect.php?url=#" onclick="ResetCaptcha(this);"><img src="/captcha.php?rnd=<?=rand(1,10000); ?>" border="0" style="margin:0;"/></a>
</td>
<td align="left" width="250" style="padding-top:20px;">Введите символы с картинки<input name="captcha" type="text" size="25" maxlength="50" /></td>
</tr>
<tr>
<td colspan="2" align="center"><BR /><input type="submit" value="Выслать ссылку" class="button_0" style="height: 30px;"></td>
</tr>
</table>

</form>
<BR />
</div>
<div class="clr"></div>
<?PHP

return;
}

# Регистрация
$_GET["key"] = (string) $_GET["key"];

$token_data = explode('-', $_GET["key"]);

$token_id = intval($token_data[0]);
$token_hash = (string) $token_data[1];

if(strlen($token_hash) != 32){ echo "<center><b><font color = 'red'>Ссылка для регистрации не действительна :(</font></b></center><BR />"; return; }

$tkey = md5($token_id."_rfs_".$token_id);
if($token_hash != $tkey){ echo "<center><b><font color = 'red'>Ссылка для регистрации не действительна :(</font></b></center><BR />"; return; }

$db->Query("SELECT * FROM db_regkey WHERE id = '$token_id' LIMIT 1");
if($db->NumRows() != 1){ echo "<center><b><font color = 'red'>Ссылка для регистрации не действительна :(</font></b></center><BR />"; return; }

$data_t = $db->FetchArray();
$db->FreeMemory();

?>
<div class="s-bk-lf">
<div class="acc-title">Регистрация</div>
</div>
<div class="silver-bk"><div class="clr"></div>
<?PHP

# Регистрация
if(isset($_POST["login"])){

$login = $func->IsLogin($_POST["login"]);
$pass = $func->IsPassword($_POST["pass"]);
$rules = isset($_POST["rules"]) ? true : false;
$time = time();
$ip = $func->UserIP;

$referer_id = $data_t["referer_id"];
$referer_name = $data_t["referer_name"];
$email = $data_t["email"];

if($rules){

if($login !== false){

if($pass !== false){

if($pass == $_POST["repass"]){

$db->Query("SELECT COUNT(*) FROM db_users_a WHERE user = '$login'");
if($db->FetchRow() == 0){

# Регаем пользователя
$db->Query("INSERT INTO db_users_a (user, email, pass, referer, referer_id, date_reg, ip)
VALUES ('$login','{$email}','$pass','$referer_name','$referer_id','$time',INET_ATON('$ip'))");

$lid = $db->LastInsert();
$db->Query("INSERT INTO db_users_b (id, user,money_b) VALUES ('$lid','$login',3000)");
# Вставляем статистику
$db->Query("UPDATE db_stats SET all_users = all_users +1 WHERE id = '1'");

# Удаляем рег кей
$db->Query("DELETE FROM db_regkey WHERE email = '$email' OR id = '$token_id'");

echo "<center><b><font color = 'green'>Вы успешно зарегистрировались. Используйте форму слева для входа в аккаунт</font></b></center><BR />";
?></div>
<div class="clr"></div>
<?PHP
return;
}else echo "<center><b><font color = 'red'>Указанный логин уже используется</font></b></center><BR />";

}else echo "<center><b><font color = 'red'>Пароль и повтор пароля не совпадают</font></b></center><BR />";

}else echo "<center><b><font color = 'red'>Пароль заполнен неверно</font></b></center><BR />";

}else echo "<center><b><font color = 'red'>Логин заполнен неверно</font></b></center><BR />";

}else echo "<center><b><font color = 'red'>Вы не подтвердили правила</font></b></center><BR />";

}


?>


<BR />
<form action="" method="post">
<table width="500" border="0" cellspacing="0" cellpadding="0">
<tr>
<td align="left" style="padding:3px;">Ваш псевдоним: <font color="#FF0000">*</font></td>
<td align="left" style="padding:3px;"><input name="login" type="text" size="25" maxlength="10" value="<?=(isset($_POST["login"])) ? $_POST["login"] : false; ?>"/></td>
</tr>
<tr>
<td colspan="2" align="left" style="padding:3px;">Поле псевдоним должно иметь от 4 до 10 символов (только англ. символы).</td>
</tr>

<tr>
<td colspan="2" align="left">&nbsp;</td>
</tr>
<tr>
<td align="left" style="padding:3px;">Пароль: <font color="#FF0000">*</font></td>
<td align="left" style="padding:3px;"><input name="pass" type="password" size="25" maxlength="20" /></td>
</tr>
<tr>
<td colspan="2" align="left" style="padding:3px;">Поле Пароль должно иметь от 6 до 20 символов (только англ. символы).</td>
</tr>
<tr>
<td align="left" style="padding:3px;">Пароль еще раз: <font color="#FF0000">*</font></td>
<td align="left" style="padding:3px;"><input name="repass" type="password" size="25" maxlength="20" /></td>
</tr>
<tr>
<td colspan="2" align="left" style="padding:3px;">Пароли должны совпадать.</td>
</tr>
<tr>
<td align="left" style="padding:3px;">Вас пригласил:</td>
<td align="left" style="padding:3px;">[ID: <?=$data_t["referer_id"];?>] <?=$data_t["referer_name"];?></td>
</tr>
<tr>
<td colspan="2" align="left">&nbsp;</td>
</tr>
<tr>
<td colspan="2" align="left" style="padding:3px;">
С <a href="https://servahoc.ru/redirect.php?url=/rules" target="_blank" class="stn">правилами</a> проекта ознакомлен(а) и принимаю: <input name="rules" type="checkbox" /></td>
</tr>
<tr>
<td colspan="2" align="left">&nbsp;</td>
</tr>
<tr>
<td colspan="2" align="center" style="padding:3px;"><input name="registr" type="submit" value="Зарегистрироваться" style="height: 30px;"></td>
</tr>
</table>
</form>

</div>
<div class="clr"></div>
 
Андрей
Участник
Сообщения
241
Реакции
55
Почему бы тебе не подарить юзеру при регистрации дерево (или что у тебя там)?
 
BigFruct
Участник
Сообщения
12
Реакции
1
Андрей написал(а):
Почему бы тебе не подарить юзеру при регистрации дерево (или что у тебя там)?
пробовал через админку к примеру начислять дерево, тоже плоды не давало, а как через админку серебра перечислишь, так сразу всё работает:(
 
Андрей
Участник
Сообщения
241
Реакции
55
BigFruct написал(а):
пробовал через админку к примеру начислять дерево, тоже плоды не давало, а как через админку серебра перечислишь, так сразу всё работает:(
я имею в виду не так.
замени в signup:
PHP:
# Регаем пользователя
                        $db->Query("INSERT INTO db_users_a (user, email, pass, referer, referer_id, date_reg, ip)
                        VALUES ('$login','{$email}','$pass','$referer_name','$referer_id','$time',INET_ATON('$ip'))");
                       
                        $lid = $db->LastInsert();
                       
                        $db->Query("INSERT INTO db_users_b (id, user, a_t, money_b, last_sbor) VALUES ('$lid','$login','1', '3000', '".time()."')");
 
mrleks
Участник
Сообщения
121
Реакции
25
ICQ
688214321 688214321
если не ошибаюсь, после регистрации (если бонусом дали дерево) нужно нажать кнопку собрать плоды, и все начинает работать
 
Сверху