Доступ к архиву

Переход в группу "Пользователь"

300.00
Одноразовый платёж
Быстрый переход в группу "Пользователи", без надобности написания постов и ожидания.

Покупка дает возможность:
Быть полноправным участником форума
Нормальное копирование кода
Создавать темы
Скачивать файлы
Доступ к архиву Pawno-Info

Помогите решить проблему

Статус
В этой теме нельзя размещать новые ответы.

Serega_Derso

Изучающий
Пользователь
Регистрация
29 Сен 2013
Сообщения
110
Лучшие ответы
0
Репутация
3
запускаю на хостинге и в игре не показывает Страну/Провайдера и тд

---------- Сообщение добавлено в 16:18 ---------- Предыдущее сообщение добавлено в 16:17 ----------

PHP:
/*
	GeoIP Include by Whitetiger
	-> SQLite GeoIP Include

	Credits: Whitetiger, RaekwonDaChef, Y_Less, Andreas Gohr.

	MaxMind, GeoIP and related marks are registered trademarks of MaxMind, Inc.

	---------------------------------------------------------------------------------------

*/

#if defined _geolocation_included
  #endinput
#endif


#define _geolocation_included

#include <a_samp>


/*
	---------------------------------------------------------------------------------------
	Variables
	---------------------------------------------------------------------------------------
*/


#if !defined GeoIP_MainFile
	#define GeoIP_MainFile      "geoip.db"
#endif

#if !defined GeoIP_CityFile
	#define GeoIP_CityFile      "geoip_city.db"
#endif

new DB:geoip_db;
new DB:geoip_city;

new stock g_iBackwardsCompat = -1;


new DBResult:_result123;

/*
	---------------------------------------------------------------------------------------
	NATIVES
	---------------------------------------------------------------------------------------
*/

/*
	native GetPlayerCountry(playerid, string[], const len = sizeof(string));
	native GetPlayerISP(playerid, string[], const len = sizeof(string));
	native GetPlayerCity(playerid, string[], const len = sizeof(string));
	native GetPlayerGMT(playerid);
	native GetPlayerProxy(playerid);
*/

stock GetPlayerCountry(playerid, string[], const len = sizeof(string)) {
	new ip[24];
	GetPlayerIp(playerid, ip, sizeof(ip));

	GetIPCountry(ip, string, len);

	return true;
}

stock GetPlayerISP(playerid, string[], const len = sizeof(string)) {
	new ip[24];
	GetPlayerIp(playerid, ip, sizeof(ip));

	GetIPISP(ip, string, len);
	new placeholder[1];
    sscanf_(string, "ss", placeholder, string);

    return true;
}

stock GetPlayerCity(playerid, string[], const len = sizeof(string)) {
	new ip[24];
	GetPlayerIp(playerid, ip, sizeof(ip));

	GetIPCity(ip, string, len);

	return true;
}

stock GetPlayerGMT(playerid) {
	new ip[24];
	GetPlayerIp(playerid, ip, sizeof(ip));

	return GetIPGMT(ip);
}

stock GetPlayerProxy(playerid) {
	new ip[24];
	GetPlayerIp(playerid, ip, sizeof(ip));

	return GetIPProxy(ip);
}

/*
	---------------------------------------------------------------------------------------
	INTERNAL FUNCTIONS
	---------------------------------------------------------------------------------------
	- stock GetIPCountry(ip[], dest[], len = sizeof(dest))
	- stock GetIPISP(ip[], dest[], len = sizeof(dest))
	- stock GetIPCity(ip[], dest[], len = sizeof(dest))
	- stock GetIPGMT(ip[])
	- stock GetIPProxy(ip[])
	- stock ip2long(ip[])
*/

stock GetIPCountry(ip[], dest[], const len = sizeof(dest)) {
	new tmp[90];
	tmp = ip2long(ip);

	new string[500];

	geoip_db = db_open(GeoIP_MainFile);

	if(g_iBackwardsCompat == -1) {
	    _result123 = db_query(geoip_db, "SELECT name FROM sqlite_master WHERE type='table' AND name='ip_country'");
	    if(db_num_rows(_result123) >= 1)
        {
            g_iBackwardsCompat = 1;
        }
        else
        {
            g_iBackwardsCompat = 0;
		}
		db_free_result(_result123);
	}

	if(g_iBackwardsCompat == 1) {
	    format(string, sizeof(string), "SELECT cn FROM ip_country WHERE idx >= (%s-(%s %% 65536)) AND ip_to >= %s AND  ip_from < %s LIMIT 1", tmp, tmp, tmp, tmp);
	} else {
		format(string, sizeof(string), "SELECT loc.*\n FROM loc_country loc,\n blocks_country blk\n WHERE blk.idx >= (%s-(%s %% 65536))\n AND blk.startIpNum < %s\n AND blk.endIpNum > %s\n AND loc.locId = blk.locId LIMIT 1;", tmp, tmp, tmp, tmp);
	}

    _result123 = db_query(geoip_db, string);
    if(db_num_rows(_result123) >= 1)
    {
  		db_get_field_assoc(_result123,"cn",dest,len);
    }
    db_free_result(_result123);
	db_close(geoip_db);

	if(!strlen(dest)) format(dest, len, "Unknown");

	return true;
}

stock GetIPISP(ip[], dest[], const len = sizeof(dest)) {

	new tmp[90];
	tmp = ip2long(ip);

	new string[500];
	format(string, sizeof(string), "SELECT internet_service_provider FROM geo_isp WHERE idx >= (%s-(%s %% 65536)) AND ip_to >= %s AND  ip_from < %s LIMIT 1", tmp, tmp, tmp, tmp);

	geoip_db = db_open(GeoIP_MainFile);
    _result123 = db_query(geoip_db, string);
    if(db_num_rows(_result123) >= 1)
    {
        db_get_field_assoc(_result123,"internet_service_provider",dest,len);
    }
    db_free_result(_result123);
	db_close(geoip_db);

	if(!strlen(dest)) format(dest, len, "Unknown");

	return true;
}

stock GetIPCity(ip[], dest[], const len = sizeof(dest)) {
	new tmp[90];
	tmp = ip2long(ip);

	new string[500];
	format(string, sizeof(string), "SELECT loc.*\n FROM geolocation loc,\n geoblocks blk\n WHERE blk.idx = (%s-(%s %% 65536))\n AND blk.startIpNum < %s\n AND blk.endIpNum > %s\n AND loc.locId = blk.locId LIMIT 1;", tmp, tmp, tmp, tmp);

	geoip_city = db_open(GeoIP_CityFile);
    _result123 = db_query(geoip_city, string);
    if(db_num_rows(_result123) >= 1)
    {
        db_get_field_assoc(_result123,"city",dest,len);
    }
    db_free_result(_result123);
	db_close(geoip_city);

	if(!strlen(dest)) format(dest, len, "Unknown");

	return true;
}

stock GetIPGMT(ip[]) {
	new tmp[90];
	tmp = ip2long(ip);

	new dest[50];

	new string[500];
	format(string, sizeof(string), "SELECT blk.*, loc.longitude\n FROM geolocation loc,\n geoblocks blk\n WHERE blk.idx = (%s-(%s %% 65536))\n AND blk.startIpNum < %s\n AND blk.endIpNum > %s\n AND loc.locId = blk.locId LIMIT 1;", tmp, tmp, tmp, tmp);

	geoip_city = db_open(GeoIP_CityFile);
    _result123 = db_query(geoip_city, string);
    if(db_num_rows(_result123) >= 1)
    {
        db_get_field_assoc(_result123, "longitude", dest, sizeof(dest));
    }
    db_free_result(_result123);
	db_close(geoip_city);

	if(!strlen(dest)) format(dest, sizeof(dest), "Unknown");

	return floatround( strval( dest ) / 15 );
}

stock GetIPProxy(ip[]) {

    /*if(g_iBackwardsCompat == -1) {
	    _result123 = db_query(geoip_db, "SELECT name FROM sqlite_master WHERE type='table' AND name='ip_country'");
	    if(db_num_rows(_result123) >= 1)
        {
            g_iBackwardsCompat = 1;
        }
        else
        {
            g_iBackwardsCompat = 0;
		}
	}

	if(g_iBackwardsCompat == 1) {
	    printf("Error: GetIPProxy cannot work on old GeoIP Database files, please update your database files!");
	    printf("http://forum.sa-mp.wiki/showthread.php?t=296171");
	    return false;
	}
	if(strlen(ip) > 0) {

		new tmp[90];
		tmp = ip2long(ip);
		new dest[50];
		new string[500];
		format(string, sizeof(string), "SELECT blk.*\n FROM geolocation loc,\n geoblocks blk\n WHERE blk.idx = (%s-(%s %% 65536))\n AND blk.startIpNum < %s\n AND blk.endIpNum > %s\n AND loc.locId = blk.locId LIMIT 1;", tmp, tmp, tmp, tmp);
		geoip_city = db_open(GeoIP_CityFile);
		_result123 = db_query(geoip_city, string);
		if(db_num_rows(_result123) >= 1)
		{
			db_get_field_assoc(_result123, "is_anonymous_proxy", dest, sizeof(dest));
		}
		db_free_result(_result123);
		db_close(geoip_city);

		return strval(dest);
	}*/

	#pragma unused ip
	return false;
}

/*forward OnProxyRecieved(index, response_code, data[]);
public OnProxyRecieved(index, response_code, data[]) {
	if(IsPlayerConnected(index)) {

		new ip[MAX_PLAYER_NAME];
		GetPlayerIp(index, ip, sizeof(ip));

		if(strlen(IPInfo[index]) > 0 && strlen(ip) > 0 && !strcmp(IPInfo[index], ip, true)) {
			CallLocalFunction("OnProxyResponse", "ii",  index, strval(data));
		}
	}
	IPInfo[index] = "";
}*/

stock ip2long(ip[]) {
	new ips[4];
	sscanf_(ip, "p.dddd", ips[0], ips[1], ips[2], ips[3]);
	new tmp[90];
	format(tmp, sizeof(tmp), "((16777216 * %d) + (65536 * %d) + (256 * %d) + %d)", ips[0], ips[1], ips[2], ips[3]);
	// we use a string here so it will not pass the 32-bit integer limits, the math is done later in the sql query
	return tmp;
}

/*
	---------------------------------------------------------------------------------------
	SECONDARY FUNCTIONS
	---------------------------------------------------------------------------------------

	- stock sscanf_(string[], format[], {Float,_}:...)
*/

stock sscanf_(string[], format[], {Float,_}:...) // by Y_Less
{
	#if defined isnull
		if (isnull(string))
	#else
		if (string[0] == 0 || (string[0] == 1 && string[1] == 0))
	#endif
		{
			return format[0];
		}
	#pragma tabsize 4
	new
		formatPos = 0,
		stringPos = 0,
		paramPos = 2,
		paramCount = numargs(),
		delim = ' ';
	while (string[stringPos] && string[stringPos] <= ' ')
	{
		stringPos++;
	}
	while (paramPos < paramCount && string[stringPos])
	{
		switch (format[formatPos++])
		{
			case '\0':
			{
				return 0;
			}
			case 'i', 'd':
			{
				new
					neg = 1,
					num = 0,
					ch = string[stringPos];
				if (ch == '-')
				{
					neg = -1;
					ch = string[++stringPos];
				}
				do
				{
					stringPos++;
					if ('0' <= ch <= '9')
					{
						num = (num * 10) + (ch - '0');
					}
					else
					{
						return -1;
					}
				}
				while ((ch = string[stringPos]) > ' ' && ch != delim);
				setarg(paramPos, 0, num * neg);
			}
			case 'h', 'x':
			{
				new
					num = 0,
					ch = string[stringPos];
				do
				{
					stringPos++;
					switch (ch)
					{
						case 'x', 'X':
						{
							num = 0;
							continue;
						}
						case '0' .. '9':
						{
							num = (num << 4) | (ch - '0');
						}
						case 'a' .. 'f':
						{
							num = (num << 4) | (ch - ('a' - 10));
						}
						case 'A' .. 'F':
						{
							num = (num << 4) | (ch - ('A' - 10));
						}
						default:
						{
							return -1;
						}
					}
				}
				while ((ch = string[stringPos]) > ' ' && ch != delim);
				setarg(paramPos, 0, num);
			}
			case 'c':
			{
				setarg(paramPos, 0, string[stringPos++]);
			}
			case 'f':
			{

				new changestr[16], changepos = 0, strpos = stringPos;
				while(changepos < 16 && string[strpos] && string[strpos] != delim)
				{
					changestr[changepos++] = string[strpos++];
   				}
				changestr[changepos] = '\0';
				setarg(paramPos,0,_:floatstr(changestr));
			}
			case 'p':
			{
				delim = format[formatPos++];
				continue;
			}
			case '\'':
			{
				new
					end = formatPos - 1,
					ch;
				while ((ch = format[++end]) && ch != '\'') {}
				if (!ch)
				{
					return -1;
				}
				format[end] = '\0';
				if ((ch = strfind(string, format[formatPos], false, stringPos)) == -1)
				{
					if (format[end + 1])
					{
						return -1;
					}
					return 0;
				}
				format[end] = '\'';
				stringPos = ch + (end - formatPos);
				formatPos = end + 1;
			}
			case 'u':
			{
				new
					end = stringPos - 1,
					id = 0,
					bool:num = true,
					ch;
				while ((ch = string[++end]) && ch != delim)
				{
					if (num)
					{
						if ('0' <= ch <= '9')
						{
							id = (id * 10) + (ch - '0');
						}
						else
						{
							num = false;
						}
					}
				}
				if (num && IsPlayerConnected(id))
				{
					setarg(paramPos, 0, id);
				}
				stringPos = end;
			}
			case 's', 'z':
			{
				new
					i = 0,
					ch;
				if (format[formatPos])
				{
					while ((ch = string[stringPos++]) && ch != delim)
					{
						setarg(paramPos, i++, ch);
					}
					if (!i)
					{
						return -1;
					}
				}
				else
				{
					while ((ch = string[stringPos++]))
					{
						setarg(paramPos, i++, ch);
					}
				}
				stringPos--;
				setarg(paramPos, i, '\0');
			}
			default:
			{
				continue;
			}
		}
		while (string[stringPos] && string[stringPos] != delim && string[stringPos] > ' ')
		{
			stringPos++;
		}
		while (string[stringPos] && (string[stringPos] == delim || string[stringPos] <= ' '))
		{
			stringPos++;
		}
		paramPos++;
	}
	do
	{
		if ((delim = format[formatPos++]) > ' ')
		{
			if (delim == '\'')
			{
				while ((delim = format[formatPos++]) && delim != '\'') {}
			}
			else if (delim != 'z')
			{
				return delim;
			}
		}
	}
	while (delim > ' ');
	return 0;
}
Это инклуд

---------- Сообщение добавлено в 16:21 ---------- Предыдущее сообщение добавлено в 16:18 ----------

Вот сама система
PHP:
callback: alogin_step_two ( playerid )
{
	new rows, fields ;
	cache_get_data ( rows, fields ) ;
	p_info [ playerid ] [ admin ] = cache_get_field_content_int ( 0, "u_a_level", sql_connection) ;

	p_info [ playerid ] [ admin_played ] = cache_get_field_content_int ( 0, "u_a_online", sql_connection) ;

	new country [ 32 ] , city [ 32 ] , provider [ 32 ] ;
	GetIPCountry(p_t_info[playerid][p_ip], country, sizeof(country));
	GetIPCity(p_t_info[playerid][p_ip], city, sizeof(city));
	GetIPISP(p_t_info[playerid][p_ip], provider, sizeof(provider));

	if ( ! rows )
	{
		new scm_string [ 128 ] ;
		format ( scm_string, sizeof ( scm_string  ), "{"#cBL"}[A]{"#cGR"} Администратор %s[%d](%d) неудачно авторизовался {"#cBL"}[%s]", p_info [ playerid ] [ name ], playerid, p_info [ playerid ] [ admin ], p_t_info [ playerid ] [ p_ip ] ) ;
		p_info [ playerid ] [ admin ] = 0 ;
		foreach(new i: admin_players) SendClientMessage ( i, 0xFF0000FF, scm_string ) ;

		format ( scm_string, sizeof ( scm_string  ), "{"#cBL"}[A]{"#cGR"} Страна: %s, город: %s, провайдер: %s", country, city, provider );
		foreach(new i: admin_players) SendClientMessage ( i, 0xFF0000FF, scm_string ) ;

		kick_player ( playerid ) ;
		return 1 ;
	}
	Iter_Add ( admin_players, playerid ) ;
	new scm_string [ 128 ] ;
	format ( scm_string, sizeof ( scm_string  ), "{"#cBL"}[A]{"#cGR"} Администратор %s[%i](%i) успешно авторизовался {"#cBL"}[%s]", p_info [ playerid ] [ name ], playerid, p_info [ playerid ] [ admin ], p_t_info [ playerid ] [ p_ip ] ) ;
	foreach(new i: admin_players) SendClientMessage ( i, 0xFF0000FF, scm_string ) ;

	format ( scm_string, sizeof ( scm_string  ), "{"#cBL"}[A]{"#cGR"} Страна: %s, город: %s, провайдер: %s", country, city, provider );
	foreach(new i: admin_players) SendClientMessage ( i, 0xFF0000FF, scm_string ) ;

	return 1;
}
 
Статус
В этой теме нельзя размещать новые ответы.
Сверху Снизу