Вопросы

Код команды:
 

Спойлер

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);
            }

 

 

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

Отредактировано пользователем odosenok
Причина: заключил код в тег "Код".

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

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

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


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

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

  • 0

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

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


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

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

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


Ссылка на сообщение
  • 0
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;
}

 

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

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


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

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

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


Ссылка на сообщение
  • 0
1 час назад, LilPokemon сказал:

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

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

Отредактировано пользователем LowanMine1
Причина: Добавление

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


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

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

Цитата

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

 

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

Цитата

printf("DEBUG-#1");

 

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

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


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

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

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


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

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

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

    • Mister Odin
      От Mister Odin
       
      new
       g_teleport_list[39][E_TELEPORT_LIST] = {  {"Спавн пгт.Батырево", 1802.3612, 2508.4824, 15.8887},  {"Спавн г.Арзамас", -113.5887, 977.7222, 12.0346},     {"Спавн г.Южный", 2744.2770, -2446.7246, 21.8988},     {"Центральный банк", 1852.020385,2040.791381,15.892713},  {"Рублёвка", -837.7783, 888.6161, 12.7232},  {"Казино", 1332.4252, 2358.7014, 17.6641},  {"Битва за контейнеры", 614.5167, 1722.3566, 12.0709},  {"Автосалон низкого класса", 2493.9616, -722.9544, 12.3315},  {"Автосалон среднего класса", 1407.7449, 455.4801, 13.1630},  {"Автосалон высокого класса", -14.0637, 2614.5664, 10.9892},   {"Мотосалон Harley Davidson", 785.720153, 750.465087, 12.000024},  {"Автошкола", 1909.174438,2227.679687,15.708162},  {"Военкомат", 1916.778564,2302.411376,15.574637},  {"Правительство области", -139.140975,593.789611,12.145712},  {"Отдел полиции №1 (ГИБДД)", 1906.805786,-2234.382812,11.257631},  {"Отдел полиции №2 (УМВД)", 2581.309326,-2416.139892,21.960090},  {"Отдел ФСБ", 1823.904663,2095.636718,15.848405},  {"Городская больница г.Арзамас", -285.797210,581.851562,12.120290},   {"СМИ", -317.708038,821.221679,13.051450},  {"Воинская часть", 1703.197265,1678.025878,15.279437},  {"Арзамасская ОПГ", 438.705322,1046.505126,12.002637},  {"Батыревская ОПГ", 1941.203857,2161.006591,15.705187},  {"Лыткаринская ОПГ", -2346.002441,75.257041,21.002962},  {"Шахта", 2381.5727, 1726.4451, -2.1506},  {"Завод", -1062.6697, 2204.1894, 38.0964},  {"Инкосация", 1864.1374, 2011.7136, 15.8546},  {"Транспортная Компания", 2362.1115, 1972.5627, 15.5530},  {"База механиков", 1840.918090,-118.025146,15.695312},  {"Курьерская служба доставки", 2764.509765,-2396.882568,21.890625},  {"Аренда автобуса(Южный)", 2771.041992,-2454.780761,21.845964},  {"Аренда автобуса(Арзамас)", -127.487670,943.652648,12.142824},   {"Аренда автобуса(Батырево)", 1798.986328,2529.591552,15.664262},  {"Гоночная трасса", -1568.7784, 1611.8305, 36.3971},  {"Дом на горе", -789.5397, -456.7479, 741.1422},  {"СТО и тюнинг-ателье", 1856.1375, -122.3266, 15.6888},  {"Аренда транспорта пгт.Батырево", 1763.641723,2255.673339,15.865348},  {"Аренда транспорта г.Арзамас", -36.923530,1360.673583,12.002090},  {"Аренда транспорта г.Южный", 1966.599975,-2603.943603,10.820312},  {"Тайный интерьер в Лыткарино", -2424.5818, 2846.3291, 40.7908} };