• 0

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

Вопросы

Прописываю команду /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 пользователей онлайн

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

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

    • От pigeon
      доброго времени суток. делал квесты для самп сервера, при компиляции возникла ошибка (9230) : error 052: multi-dimensional arrays must be fully initialized. помогите, пожалуйста, я чайник. ошибка в строке 9230.
      P. S. на орфографию в квестах не обращайте внимания,  это не я писал.
       
       

    • От Tookie Johnson
      Здравствуйте, не будет ли у кого нибудь системы анти-толкания транспортного средства для всего сервера?