• 0
Rikson

Проблема с реферальной системой

Вопросы

Прописываю команду /referal в самп, появляется меню, кликаю ввести ник, ввожу, кликаю "окей" и ничего не происходит, а менюшка закрывается. Я предоставил весь код, связанный с этой командой

Спойлер

case 1070: {
	if(!response) return 1;
	switch(listitem)
	{
		case 0: {
			ShowPlayerDialog(playerid, 0000, DIALOG_STYLE_MSGBOX, ""cMain"| "WHITE"Реферальная система", ""SERVER"Система рефералов "WHITE"- Ваш путь к халявным донат рублям, на которые Вы сможете приобрести права администратора и многое другое.\n\n\
			Как это работает?\n\n\
			"cMain"| "WHITE" Ваш друг указывает Ваш ник в "SERVER"/referal"WHITE", тем самым подтверждает что Вы его пригласили на сервер.\n\
			"cMain"| "WHITE" После того как Ваш друг отыграет на сервере "SERVER"20 часов"WHITE", Вы и Ваш друг получите по "SERVER"5 донат рублей."WHITE"\n\
			"cMain"| "WHITE" Вы можете приглашать не более "SERVER"20 друзей "WHITE"и получить не более "SERVER"100 рублей "WHITE"на аккаунт.\n\
			"cMain"| "WHITE" В любой может Вы можете посмотреть статистику по приглашенным друзьям во вкладке "SERVER"'Реферальная система'", "Понял","");
		}
		case 1: playerReferalPage[playerid] = 0, ReferalStock(playerid);
		case 2:
		{
			if(PlayerInfo[playerid][ReferalActive] == 0) ShowPlayerDialog(playerid, 1071, DIALOG_STYLE_INPUT, ""SERVER"Реферальная система", "{FFFFFF}Введите ник игрока, который вас пригласил:", "Ввести", "Выйти");
			else SendClientMessage(playerid, -1, ""cError"Вы уже привязанны!");
		}
	}
	return 1;
}
case 1071: {
	if(!response) return 1;
	if(!strcmp(PlayerInfo[playerid][pNames], inputtext)) return SendClientMessage(playerid, -1, ""cError"Данный ник не найден в базе данных");
	mysql_format(connects,string,156, "SELECT * FROM `accounts` WHERE `Name` = '%s'", inputtext);
	mysql_tquery(connects, string, "CheckReferal", "ds", playerid, inputtext);
	return 1;
}

 

 

Спойлер

CMD:referal(playerid, params[])
{
    ShowPlayerDialog(playerid, 1070, DIALOG_STYLE_LIST, ""cMain"| "WHITE"Реферальная система", "{FFFFFF}1. Что это такое?\n2. Моя реферальная система\n3. Ввести реферал", "Продолжить", "Выйти");
    return 1;
}
publics: ReferalStockError(playerid)
{
      playerReferalPage[playerid]--;
    ReferalStock(playerid);
    return 1;
}
ReferalStock(playerid)
{
    new page = playerReferalPage[playerid], count1, strings[500] = ""WHITE"Ник\tЧасы\n";
    nfor(i, MAX_REFERAL) if(strcmp(MyReferals[playerid], "None"))
    {
        count1++;
        if(count1 > page*15 && count1 <= page*15+15)
        {
             format(strings, 500, "%s%s\t%i/20\n", strings, MyReferals[playerid], PlayerInfo[playerid][MyReferalsPayDays]);
        }
    }
    if(strlen(strings) < 24)
    {
        if(page) SetTimerEx("ReferalStockError", 0, 0, "i", playerid);
        return SendClientMessage(playerid, -1, ""cError"Рефералы не найдены");
    }
    strcat(strings, "Следующая страница\n");
    if(page) strcat(strings, "Предыдущая страница");
    new cstr[50];
    valstr(cstr, page+1);
    strins(cstr, ""SERVER"Список рефералов: ", 0);
    ShowPlayerDialog(playerid, 124, 5, cstr, strings, "Выбрать", "Закрыть");
    return 1;
}
publics: CheckReferal(playerid, nick[])
{
    new rows,fields;
    cache_get_data(rows,fields,connects);
    if(!rows) return SendClientMessage(playerid, -1, ""cError"Данный ник не найден в базе данных.");
    new id_player = GetPlayerID(nick);
    if(IsPlayerConnected(id_player))
    {
        new tmp;
        nfor(i, MAX_REFERAL) if(!strcmp(MyReferals[id_player], "None"))
        {
            tmp = i+1;
            break;
        }
        if(!tmp) return SendClientMessage(playerid, -1, ""cError"Все места заняты"); 

        format(PlayerInfo[playerid][ReferalAccount], 25, nick);
        format(MyReferals[id_player][tmp-1], 25, PlayerInfo[playerid][pNames]);
        PlayerInfo[playerid][ReferalActive] = tmp; 

        mysql_format(connects,string, MAX_STR, "UPDATE `accounts` SET `MyReferals%i` = '%s' WHERE `Name` = '%s'", tmp, PlayerInfo[playerid][pNames], PlayerInfo[playerid][ReferalAccount]);
        mysql_tquery(connects, string); 

        SendClientMessagef(id_player, -1, ""WHITE"На вашу реферальну систему подписался "SERVER"%s. "WHITE"Введите "SERVER"/referal"WHITE" чтоб посмотреть", PlayerInfo[playerid][pNames]);
        SendClientMessagef(playerid, -1, ""WHITE"Вы подписались на реферальную систему "SERVER"%s. "WHITE"Чтоб получить 5 рублей, отыграйте "SERVER"20 часов.", PlayerInfo[id_player][pNames]); 

        mysql_format(connects,string, MAX_STR, "UPDATE `accounts` SET `ReferalAccount` = '%s', `ReferalActive` = '%i', `ReferalPayDay` = '0' WHERE `Name` = '%s'",nick, tmp ,PlayerInfo[playerid][pNames]);
        mysql_tquery(connects, string);
    }
    else SetTimerEx("CheckReferalTwo", 0, 0, "ds", playerid, nick);
    return 1;
}
publics: CheckReferalTwo(playerid, nick[])
{
    format(string, 400, "SELECT `MyReferals1`, `MyReferals2`,`MyReferals3`,`MyReferals4`,`MyReferals5`,`MyReferals6`,`MyReferals7`,`MyReferals8`,`MyReferals9`,`MyReferals10`,`MyReferals11`,`MyReferals12`,`MyReferals13`,`MyReferals14`,`MyReferals15`,`MyReferals16`,`MyReferals17`,`MyReferals18`,`MyReferals19`,`MyReferals20` FROM `accounts` WHERE `Name` = '%s'", nick);
    mysql_tquery(connects, string, "CheckReferalThree", "ds", playerid, nick);
    return 1;
}
publics: CheckReferalThree(playerid, nick[])
{
    new rows,fields;
    cache_get_data(rows,fields,connects);
    if(!rows) return SendClientMessage(playerid, -1, ""cError"Упс, у нас ошибочка... Напишите об этом администраторам!");
    new check_none[20][25], strings[50];
    nfor(i, fields)
    {
        valstr(strings, i+1);
        strins(strings, "MyReferals", 0);
        cache_get_field_content(0, strings, check_none, connects);
    } 

     new tmp;
    nfor(i, MAX_REFERAL) if(!strcmp(check_none, "None"))
    {
        tmp = i+1;
        break;
    }
    if(!tmp) return SendClientMessage(playerid, -1, ""cError"Все места заняты"); 

    format(PlayerInfo[playerid][ReferalAccount], 25, nick);
    SendClientMessagef(playerid, -1, ""WHITE"Вы подписались на реферальную систему "SERVER"%s. Чтоб получить приз в размере "SERVER"5 "WHITE"рублей, отыграйте "SERVER"20 "WHITE"часов.", PlayerInfo[playerid][ReferalAccount]); 

    mysql_format(connects,string, MAX_STR, "UPDATE `accounts` SET `MyReferals%i` = '%s' WHERE `Name` = '%s'", tmp, PlayerInfo[playerid][pNames], PlayerInfo[playerid][ReferalAccount]);
    mysql_tquery(connects, string); 

    mysql_format(connects,string, MAX_STR, "UPDATE `accounts` SET `ReferalAccount` = '%s', `ReferalActive` = '%i', `ReferalPayDay` = '0' WHERE `Name` = '%s'",PlayerInfo[playerid][ReferalAccount], tmp ,PlayerInfo[playerid][pNames]);
    mysql_tquery(connects, string);
    return 1;
} 

 

Заметка от Cawfee , создано

Пожалуйста, ознакомьтесь с информацией о том, как правильно выкладывать код на форум.

Поделиться сообщением


Ссылка на сообщение

3 ответа на этот вопрос

  • 0

@Rikson, реферал, ник которого Вы указываете, находится в игре в этот момент?

Поделиться сообщением


Ссылка на сообщение
  • 0

 

15 часов назад, odosenok сказал:

@Rikson, реферал, ник которого Вы указываете, находится в игре в этот момент?

Нет, не находится. Я более точно изучил работу этой команды и вот, что показало моё исследование: При вводе команды /referal открывается меню, клацаю на ввод Реферала, ввожу ник, меню закрывается. Открываю снова, ввожу ник, снова закрывается и т.д. а если ввожу свой ник, то пишет "нельзя использовать свой ник" Затем перезапускаю игру, пытаюсь ввести ник и пишет, что реферал зарегестрирован, тыкал на нескольких аккаунтах вкладку "мои рефералы", пишет, что их у меня нет. По достижению 20 часов, должен даваться бонус, но его нет. В таблице mysql на всех тестовых аккаунтах показывает не больше 1 реферала, хоть регал больше.

 

Поделиться сообщением


Ссылка на сообщение
  • 0

@Rikson, а покажите-ка еще for. Ну, или скажите сами, с нуля или единицы цикл начинается.

Поделиться сообщением


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Узбек
      От Узбек
      Всем добрый вечер ребят! 
      Я начинающий, сегодня я вам сливаю команду 2(шт) на технические работы
      Ловите 
       
    • nazpol9
      От nazpol9
      Привет всем.

      У меня имеется мод для самп сервера и VPS с Ubuntu, на котором я пытаюсь его запустить.

      В чем суть проблемы: при запуске samp03svr, сервер запускается, но на версии 0.3.DL R-1. Когда я пытаюсь запустить этот же мод локально на Windows, сервер работает на версии 0.3.7 и я могу зайти на него без клиента 0.3.DL.

      Для решения этой проблемы я уже пробовал заменять инклуды и исполнительные файлы теми, что есть в архивах на официальном сайте сампа, перекомпилировал мод, и ничего не изменилось.
       
      #include <a_samp> #include <a_mysql> #include <foreach> #include <Pawn.RakNet> #include <streamer> #include <sscanf2> #include <float2> #include <crashdetect> #include <fmt> #include <a_http> #include <Pawn.CMD> #include <Pawn.Regex> #include <requests> #include <callbacks> #include <MD5> #include <mxdate> #include <TOTP> #include <gvar> #include <md-sort> #include <nex-ac> #include <weapon-config> #include <discord-connector> #include <3DTryg> #include <textdraw-streamer>  
      plugins crashdetect.so streamer.so textdraw-streamer.so sscanf.so pawnraknet.so pawncmd.so mysql.so requests.so profiler.so pawnregex.so TOTP.so gvar.so discord-connector.so

      Если у кого-то будут какие-либо догадки, прошу ими поделиться, если понадобится больше информации - я постараюсь её предоставить.