Рекомендованные сообщения



Не найдено.

8 posts in this topic

Код команды:
 

Спойлер

cmd:alogin(playerid, params[])
{
    if(GetPVarInt(playerid, "check_alogin") > gettime()) return 1;
    else if(AdminLogged[playerid]) return SendErr(playerid, "Вы уже авторизовались как администратор!");

    new string[128];
    format(string, sizeof(string), "SELECT * FROM "T_ADMIN" WHERE `name` = '%s'", GetName(playerid));
    mysql_tquery(dbHandle, string, "Alogin", "is", playerid, GetName(playerid));
    SetPVarInt(playerid, "check_alogin", gettime()+5);
    return 1;
}

 

Спойлер

     case D_ALOGIN:
    {
        if(!response) return 1;
        new string[144];
        switch(GetPVarInt(playerid,"aLogin"))
        {
            case 1:
            {
                if(!strlen(inputtext)|| !strcmp(inputtext, "qwerty", true) || strlen(inputtext) < 6 || strlen(inputtext) > 16 || strfind(inputtext, "=", true) != -1)
                    return ShowPlayerDialog(playerid, D_ALOGIN, DIALOG_STYLE_PASSWORD, "Регистрация администратора", "\
                    {FFFFFF}Введите пароль, который будет от панели администратора\n\n\
                    {63BD4E}Примечание:\n\
                    \t- Пароль должен состоять из латинских букв и цифр\n\
                    \t- Размер пароля от 6 до 15 символов", "Принять", "Отмена");
                SetPVarString(playerid, "inputtext", inputtext);
                format(string, sizeof(string), "SELECT * FROM "T_ADMIN" WHERE `name` = '%s'", GetName(playerid));
                mysql_tquery(dbHandle, string, "AloginReg", "is", playerid, GetName(playerid));
            }
            case 0:
            {
                if(!strlen(inputtext)) return ShowPlayerDialog(playerid, D_ALOGIN, DIALOG_STYLE_PASSWORD, "Доступ администратора", "\
                {FFFFFF}Введите Ваш пароль от панели администратора", "Принять", "Отмена");
                mysql_format(dbHandle, string, sizeof(string), "SELECT * FROM "T_ADMIN" WHERE `name` = '%s' AND `password` = '%e'", GetName(playerid), inputtext);
                mysql_tquery(dbHandle, string, "AloginAuth", "is", playerid, inputtext);
            }

 

 

В чём проблема? Просьба помочь.

Edited by odosenok
Причина: заключил код в тег "Код".

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

Внимательно изучите урок по поводу того, как правильно выкладывать код на форум.

Share this post


Link to post
Share on other sites

Забыл написать о проблеме: Не открывается менюшка самой /alogin.

Share this post


Link to post
Share on other sites

Паблик/сток  Alogin скинь пожалуйста

Share this post


Link to post
Share on other sites
20 минут назад, LilPokemon сказал:

Паблик/сток  Alogin скинь пожалуйста

Спойлер

forward Alogin(playerid, name[]);
public Alogin(playerid, name[])
{
	new rows, fields;
	cache_get_data(rows, fields);
	if(!rows)
	{
		if(PI[playerid][pAdmin] > 0) PI[playerid][pAdmin] = 0;
		return 1;
	}
	new Password[16];
	cache_get_field_content(0, "password", Password, dbHandle);
	if(!strcmp(Password, "qwerty", true))
	{
		SetPVarInt(playerid, "aLogin", 1);
		ShowPlayerDialog(playerid, D_ALOGIN, DIALOG_STYLE_INPUT, "Регистрация администратора", "\
		{FFFFFF}Введите пароль, который будет от панели администратора\n\n\
		{63BD4E}Примечание:\n\
		\t- Пароль должен состоять из латинских букв и цифр\n\
		\t- Размер пароля от 6 до 15 символов", "Принять", "Отмена");
	}
	else
	{
		SetPVarInt(playerid, "aLogin", 0);
		ShowPlayerDialog(playerid, D_ALOGIN, DIALOG_STYLE_INPUT, "Доступ администратора", "\
		{FFFFFF}Введите Ваш пароль от панели администратора", "Принять", "Отмена");
	}
	return 1;
}

forward AloginReg(playerid, name[]);
public AloginReg(playerid, name[])
{
	new rows, fields;
	cache_get_data(rows, fields);
	if(!rows) return 1;
	new inputtext[16], string[144],string1[144], ipplayer[256];
	GetPVarString(playerid, "inputtext", inputtext, sizeof(inputtext));
	mysql_format(dbHandle, string, sizeof(string), "UPDATE "T_ADMIN" SET `password` = '%s' WHERE `name` = '%s' LIMIT 1", inputtext, GetName(playerid));
	mysql_tquery(dbHandle, string, "", "");
	PI[playerid][pAdmin] = cache_get_row_int(0, 1, dbHandle);
	GetPlayerIp(playerid,ipplayer,sizeof(ipplayer));
	MysqlUpdatePlayerInt(playerid, "admin", PI[playerid][pAdmin]);
	static const Admin_Names[9][32] = {"Новичек","Мл.Модератор","Модератор","Ст. Модератор","Мл.Администратор","Администратор","Гл. Администратор","Спец.Администратор","Создатель"};
	if(PI[playerid][pSex] == 1) format(string, sizeof(string), ""cAD"%s %s[%i] авторизовался [IP: %s | R-IP %s]", Admin_Names[PI[playerid][pAdmin]-1], GetName(playerid), playerid,  PI[playerid][pLastIP],PI[playerid][pRegIP]);
	else format(string, sizeof(string), "%s %s[%i] авторизовалась [IP: %s | R-IP %s]", Admin_Names[PI[playerid][pAdmin]-1], GetName(playerid), playerid, ipplayer,PI[playerid][pIP]);

	if(GetString(GetName(playerid), NGA1) || GetString(GetName(playerid), NGA4) || GetString(GetName(playerid), NGA7) || GetString(GetName(playerid), NGA2))
	{
		format(string1, sizeof(string1), "Владелец %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
	}
	else if(GetString(GetName(playerid), NGA6) || GetString(GetName(playerid), NGA5))
	{
 		format(string1, sizeof(string1), "Руководитель %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
	}
	else if(GetString(GetName(playerid), NGA3) || GetString(GetName(playerid), NGA8) || GetString(GetName(playerid), NGA9))
	{
		format(string1, sizeof(string1), "Следящий за сервером %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
	}
	else if(GetString(GetName(playerid), NGA12))
	{
 		format(string1, sizeof(string1), "Зам.Владельца %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
	}
	else if(GetString(GetName(playerid), NGA13))
	{
 		format(string1, sizeof(string1), "МАПпер %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
	}
	else if(GetString(GetName(playerid), NGA10))
	{
 		format(string1, sizeof(string1), "Главный по лидеркам %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
	}
	else if(GetString(GetName(playerid), NGA11))
	{
 		format(string1, sizeof(string1), "Зам.Главного по лидеркам %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
	}

	SendAdminMessage(COLOR_BLUE, string);
	SendAdminMessage(COLOR_BLUE, string1);
	AdminLogged[playerid] = true;
	Itter_Add(Admins, playerid);
	new day, month, year;
	getdate(year, month, day);
	mysql_format(dbHandle, string, sizeof(string), "UPDATE "T_ADMIN" SET `last_connect` = '%d.%d.%d' WHERE `name` = '%s' LIMIT 1", day, month, year, GetName(playerid));
	mysql_tquery(dbHandle, string, "", "");
	new ip[16];
	GetPlayerIp(playerid,ip,sizeof(ip));
	return 1;
}

forward AloginAuth(playerid, inputtext[]);
public AloginAuth(playerid, inputtext[])
{
	new rows, fields;
	cache_get_data(rows, fields);
	if(!rows)
	{
		SendErr(playerid, "Неверный пароль");
		SetPVarInt(playerid, "attempt_pass", GetPVarInt(playerid, "attempt_pass") + 1);
		if(GetPVarInt(playerid, "attempt_pass") > 3)
		{
			DeletePVar(playerid, "attempt_pass");
			Kick(playerid);
		}
	}
	else
	{
	    new string[240], ipplayer[256];
		AdminLogged[playerid] = true;
		PI[playerid][pAdmin] = cache_get_row_int(0, 1, dbHandle);
		AdminInfo[playerid][admGoto] = cache_get_row_int(0, 6, dbHandle);
	    AdminInfo[playerid][admGethere] = cache_get_row_int(0, 7, dbHandle);
	    AdminInfo[playerid][admSpectate] = cache_get_row_int(0, 8, dbHandle);
	    AdminInfo[playerid][admTimeMin] = cache_get_row_int(0, 9, dbHandle);
	    GetPlayerIp(playerid,ipplayer,sizeof(ipplayer));
		static const Admin_Names[9][32] = {"Новичек","Мл.Модератор","Модератор","Ст. Модератор","Мл.Администратор","Администратор","Гл. Администратор","Спец.Администратор","Создатель"};
		if(PI[playerid][pSex] == 1) format(string, sizeof(string), ""cAD"%s %s[%i] авторизовался [IP: %s | R-IP %s]", Admin_Names[PI[playerid][pAdmin]-1], GetName(playerid), playerid,  PI[playerid][pLastIP],PI[playerid][pRegIP]);
		else format(string, sizeof(string), "%s %s[%i] авторизовалась [IP: %s | R-IP %s]", Admin_Names[PI[playerid][pAdmin]-1], GetName(playerid), playerid, ipplayer,PI[playerid][pIP]);

		if(GetString(GetName(playerid), NGA1) || GetString(GetName(playerid), NGA4) || GetString(GetName(playerid), NGA7) || GetString(GetName(playerid), NGA2))
		{
			format(string, sizeof(string), "Владелец %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
		}
		else if(GetString(GetName(playerid), NGA6) || GetString(GetName(playerid), NGA5))
		{
	 		format(string, sizeof(string), "Руководитель %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
		}
		else if(GetString(GetName(playerid), NGA3) || GetString(GetName(playerid), NGA8) || GetString(GetName(playerid), NGA9))
		{
			format(string, sizeof(string), "Следящий за сервером %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
		}
		else if(GetString(GetName(playerid), NGA12))
		{
	 		format(string, sizeof(string), "Зам.Владельца %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
		}
		else if(GetString(GetName(playerid), NGA13))
		{
	 		format(string, sizeof(string), "МАПпер %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
		}
		else if(GetString(GetName(playerid), NGA10))
		{
	 		format(string, sizeof(string), "Главный по лидеркам %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
		}
		else if(GetString(GetName(playerid), NGA11))
		{
	 		format(string, sizeof(string), "Зам.лавного по лидеркам %s[%i] авторизовался [IP: 126.1.0.1 | R-IP 126.1.0.1]", GetName(playerid), playerid);
		}

		SendAdminMessage(COLOR_BLUE, string);
        Itter_Add(Admins, playerid);
		new day, month, year;
  		getdate(year, month, day);
		mysql_format(dbHandle, string, 144, "UPDATE "T_ADMIN" SET `last_connect` = '%d.%d.%d' WHERE `name` = '%s' LIMIT 1", day, month, year, GetName(playerid));
		mysql_tquery(dbHandle, string, "", "");

	}
	return 1;
}

 

Не знал что кидать, поэтому скинул всё

Share this post


Link to post
Share on other sites

У тебя появляется диалог ? 

Share this post


Link to post
Share on other sites
1 час назад, LilPokemon сказал:

У тебя появляется диалог ? 

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

Edited by LowanMine1
Причина: Добавление

Share this post


Link to post
Share on other sites

@LowanMine1 Вставьте после 

Цитата

 if(GetPVarInt(playerid, "check_alogin") > gettime()) return 1;

 

Вот это, что-бы посмотреть проходит ли проверка?

Цитата

printf("DEBUG-#1");

 

И  посмотри будет ли появляться это сообщение в консоли.

Share this post


Link to post
Share on other sites

Попробуй диалог D_ALOGIN разбирать на 2, то есть, не по PVar'ам что бы сверялось, а отдельные диалоги для авторизации и регистрации.

Share this post


Link to post
Share on other sites
Guest
This topic is now closed to further replies.

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • .037
      By .037
      в чём может быть проблема? Передаю строку через PR_String, и получаю с клиента бред
      CMD:TestData(playerid, params[]){ new msg[] = "Code_Test"; new BitStream:bs = BS_New(); BS_WriteInt8(bs,30); BS_WriteFloat(bs,0.9); BS_WriteFloat(bs,23.4); BS_WriteString(bs, msg, sizeof msg); PR_SendRPC(bs, playerid, 179); BS_Delete(bs); return 1; } [05:57:27] RPC - Длина  30 | 0.900000 | 23.400000 | I*(!@dp
      И всегда текст разный 

      Хотя принимаю всё нормально:

       
      bool CALLBACK Hok_RPC_BYTE(stRakNetHookParams *params) { if (params->packetId == 179) { SF->getSAMP()->getChat()->AddChatMessage(D3DCOLOR_XRGB(0, 0xAA, 0), "Кастомный RPC работает!!!"); byte nameLen; float test; float test1; char szPlayerName[100]; params->bitStream->ResetReadPointer(); params->bitStream->Read(nameLen); params->bitStream->Read(test); params->bitStream->Read(test1); params->bitStream->Read(szPlayerName, 100); params->bitStream->ResetReadPointer(); SF->getSAMP()->getChat()->AddChatMessage(D3DCOLOR_XRGB(0, 0xAA, 0), "RPC - Длина %d | %f | %f | %s", nameLen, test , test1, szPlayerName); } return true; };