Geoip: Convert code to libmaxminddb API.
This commit is contained in:
parent
9d59de41a2
commit
7dd1ea3719
@ -1,10 +1,11 @@
|
|||||||
# vim: set sts=2 ts=8 sw=2 tw=99 et ft=python:
|
# vim: set sts=2 ts=8 sw=2 tw=99 et ft=python:
|
||||||
import os.path
|
import os.path
|
||||||
|
|
||||||
binary = AMXX.Module(builder, 'geoip')
|
binary = AMXX.MetaModule(builder, 'geoip')
|
||||||
|
|
||||||
binary.compiler.defines += ['HAVE_STDINT_H']
|
binary.compiler.defines += [
|
||||||
binary.compiler.includes += [os.path.join(builder.sourcePath, 'dlls', 'geoip', 'GeoIP2')]
|
'HAVE_STDINT_H'
|
||||||
|
]
|
||||||
|
|
||||||
binary.sources = [
|
binary.sources = [
|
||||||
'sdk/amxxmodule.cpp',
|
'sdk/amxxmodule.cpp',
|
||||||
@ -14,5 +15,6 @@ binary.sources = [
|
|||||||
|
|
||||||
if builder.target_platform == 'windows':
|
if builder.target_platform == 'windows':
|
||||||
binary.compiler.postlink += ['ws2_32.lib']
|
binary.compiler.postlink += ['ws2_32.lib']
|
||||||
|
binary.compiler.includes += [os.path.join(builder.sourcePath, 'dlls', 'geoip', 'GeoIP2')]
|
||||||
|
|
||||||
AMXX.modules += [builder.Add(binary)]
|
AMXX.modules += [builder.Add(binary)]
|
||||||
|
@ -25,6 +25,66 @@ typedef ADDRESS_FAMILY sa_family_t;
|
|||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
const char GeoIPCountryCode[][3] =
|
||||||
|
{
|
||||||
|
"AP", "EU", "AD", "AE", "AF", "AG", "AI", "AL", "AM", "AN",
|
||||||
|
"AO", "AQ", "AR", "AS", "AT", "AU", "AW", "AZ", "BA", "BB",
|
||||||
|
"BD", "BE", "BF", "BG", "BH", "BI", "BJ", "BM", "BN", "BO",
|
||||||
|
"BR", "BS", "BT", "BV", "BW", "BY", "BZ", "CA", "CC", "CD",
|
||||||
|
"CF", "CG", "CH", "CI", "CK", "CL", "CM", "CN", "CO", "CR",
|
||||||
|
"CU", "CV", "CX", "CY", "CZ", "DE", "DJ", "DK", "DM", "DO",
|
||||||
|
"DZ", "EC", "EE", "EG", "EH", "ER", "ES", "ET", "FI", "FJ",
|
||||||
|
"FK", "FM", "FO", "FR", "FX", "GA", "GB", "GD", "GE", "GF",
|
||||||
|
"GH", "GI", "GL", "GM", "GN", "GP", "GQ", "GR", "GS", "GT",
|
||||||
|
"GU", "GW", "GY", "HK", "HM", "HN", "HR", "HT", "HU", "ID",
|
||||||
|
"IE", "IL", "IN", "IO", "IQ", "IR", "IS", "IT", "JM", "JO",
|
||||||
|
"JP", "KE", "KG", "KH", "KI", "KM", "KN", "KP", "KR", "KW",
|
||||||
|
"KY", "KZ", "LA", "LB", "LC", "LI", "LK", "LR", "LS", "LT",
|
||||||
|
"LU", "LV", "LY", "MA", "MC", "MD", "MG", "MH", "MK", "ML",
|
||||||
|
"MM", "MN", "MO", "MP", "MQ", "MR", "MS", "MT", "MU", "MV",
|
||||||
|
"MW", "MX", "MY", "MZ", "NA", "NC", "NE", "NF", "NG", "NI",
|
||||||
|
"NL", "NO", "NP", "NR", "NU", "NZ", "OM", "PA", "PE", "PF",
|
||||||
|
"PG", "PH", "PK", "PL", "PM", "PN", "PR", "PS", "PT", "PW",
|
||||||
|
"PY", "QA", "RE", "RO", "RU", "RW", "SA", "SB", "SC", "SD",
|
||||||
|
"SE", "SG", "SH", "SI", "SJ", "SK", "SL", "SM", "SN", "SO",
|
||||||
|
"SR", "ST", "SV", "SY", "SZ", "TC", "TD", "TF", "TG", "TH",
|
||||||
|
"TJ", "TK", "TM", "TN", "TO", "TL", "TR", "TT", "TV", "TW",
|
||||||
|
"TZ", "UA", "UG", "UM", "US", "UY", "UZ", "VA", "VC", "VE",
|
||||||
|
"VG", "VI", "VN", "VU", "WF", "WS", "YE", "YT", "RS", "ZA",
|
||||||
|
"ZM", "ME", "ZW", "A1", "A2", "O1", "AX", "GG", "IM", "JE",
|
||||||
|
"BL", "MF"
|
||||||
|
};
|
||||||
|
|
||||||
|
const char GeoIPCountryCode3[][4] =
|
||||||
|
{
|
||||||
|
"AP", "EU", "AND", "ARE", "AFG", "ATG", "AIA", "ALB", "ARM", "ANT",
|
||||||
|
"AGO", "AQ", "ARG", "ASM", "AUT", "AUS", "ABW", "AZE", "BIH", "BRB",
|
||||||
|
"BGD", "BEL", "BFA", "BGR", "BHR", "BDI", "BEN", "BMU", "BRN", "BOL",
|
||||||
|
"BRA", "BHS", "BTN", "BV", "BWA", "BLR", "BLZ", "CAN", "CC", "COD",
|
||||||
|
"CAF", "COG", "CHE", "CIV", "COK", "CHL", "CMR", "CHN", "COL", "CRI",
|
||||||
|
"CUB", "CPV", "CX", "CYP", "CZE", "DEU", "DJI", "DNK", "DMA", "DOM",
|
||||||
|
"DZA", "ECU", "EST", "EGY", "ESH", "ERI", "ESP", "ETH", "FIN", "FJI",
|
||||||
|
"FLK", "FSM", "FRO", "FRA", "FX", "GAB", "GBR", "GRD", "GEO", "GUF",
|
||||||
|
"GHA", "GIB", "GRL", "GMB", "GIN", "GLP", "GNQ", "GRC", "GS", "GTM",
|
||||||
|
"GUM", "GNB", "GUY", "HKG", "HM", "HND", "HRV", "HTI", "HUN", "IDN",
|
||||||
|
"IRL", "ISR", "IND", "IO", "IRQ", "IRN", "ISL", "ITA", "JAM", "JOR",
|
||||||
|
"JPN", "KEN", "KGZ", "KHM", "KIR", "COM", "KNA", "PRK", "KOR", "KWT",
|
||||||
|
"CYM", "KAZ", "LAO", "LBN", "LCA", "LIE", "LKA", "LBR", "LSO", "LTU",
|
||||||
|
"LUX", "LVA", "LBY", "MAR", "MCO", "MDA", "MDG", "MHL", "MKD", "MLI",
|
||||||
|
"MMR", "MNG", "MAC", "MNP", "MTQ", "MRT", "MSR", "MLT", "MUS", "MDV",
|
||||||
|
"MWI", "MEX", "MYS", "MOZ", "NAM", "NCL", "NER", "NFK", "NGA", "NIC",
|
||||||
|
"NLD", "NOR", "NPL", "NRU", "NIU", "NZL", "OMN", "PAN", "PER", "PYF",
|
||||||
|
"PNG", "PHL", "PAK", "POL", "SPM", "PCN", "PRI", "PSE", "PRT", "PLW",
|
||||||
|
"PRY", "QAT", "REU", "ROU", "RUS", "RWA", "SAU", "SLB", "SYC", "SDN",
|
||||||
|
"SWE", "SGP", "SHN", "SVN", "SJM", "SVK", "SLE", "SMR", "SEN", "SOM",
|
||||||
|
"SUR", "STP", "SLV", "SYR", "SWZ", "TCA", "TCD", "TF", "TGO", "THA",
|
||||||
|
"TJK", "TKL", "TKM", "TUN", "TON", "TLS", "TUR", "TTO", "TUV", "TWN",
|
||||||
|
"TZA", "UKR", "UGA", "UM", "USA", "URY", "UZB", "VAT", "VCT", "VEN",
|
||||||
|
"VGB", "VIR", "VNM", "VUT", "WLF", "WSM", "YEM", "YT", "SRB", "ZAF",
|
||||||
|
"ZMB", "MNE", "ZWE", "A1", "A2", "O1", "ALA", "GGY", "IMN", "JEY",
|
||||||
|
"BLM", "MAF"
|
||||||
|
};
|
||||||
|
|
||||||
#define MMDB_DATA_TYPE_EXTENDED (0)
|
#define MMDB_DATA_TYPE_EXTENDED (0)
|
||||||
#define MMDB_DATA_TYPE_POINTER (1)
|
#define MMDB_DATA_TYPE_POINTER (1)
|
||||||
#define MMDB_DATA_TYPE_UTF8_STRING (2)
|
#define MMDB_DATA_TYPE_UTF8_STRING (2)
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
<<<<<<< HEAD
|
||||||
// vim: set ts=4 sw=4 tw=99 noet:
|
// vim: set ts=4 sw=4 tw=99 noet:
|
||||||
//
|
//
|
||||||
// AMX Mod X, based on AMX Mod by Aleksander Naszko ("OLO").
|
// AMX Mod X, based on AMX Mod by Aleksander Naszko ("OLO").
|
||||||
@ -13,103 +14,328 @@
|
|||||||
|
|
||||||
#include "geoip_amxx.h"
|
#include "geoip_amxx.h"
|
||||||
|
|
||||||
GeoIP *gi = NULL;
|
MMDB_s HandleDB;
|
||||||
|
|
||||||
inline void StripPort(char *ip)
|
char *stripPort(char *ip_port)
|
||||||
{
|
{
|
||||||
char *tmp = strchr(ip, ':');
|
char *tmp = strchr(ip_port, ':');
|
||||||
|
|
||||||
if (!tmp)
|
if (!tmp)
|
||||||
return;
|
{
|
||||||
|
return ip_port;
|
||||||
|
}
|
||||||
|
|
||||||
*tmp = '\0';
|
*tmp = '\0';
|
||||||
|
|
||||||
|
return tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char *lookupByIp(const char *ip, const char **path, int *length = NULL)
|
||||||
|
{
|
||||||
|
int gai_error = 0, mmdb_error = 0;
|
||||||
|
MMDB_lookup_result_s lookup = MMDB_lookup_string(&HandleDB, ip, &gai_error, &mmdb_error);
|
||||||
|
|
||||||
|
if (gai_error != 0 || MMDB_SUCCESS != mmdb_error || !lookup.found_entry)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
MMDB_entry_data_s entry_data;
|
||||||
|
MMDB_aget_value(&lookup.entry, &entry_data, path);
|
||||||
|
|
||||||
|
if (!entry_data.has_data)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (length)
|
||||||
|
{
|
||||||
|
*length = entry_data.data_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
return entry_data.utf8_string;
|
||||||
|
}
|
||||||
|
|
||||||
|
// native geoip_code2(const ip[], ccode[3]);
|
||||||
|
// Deprecated.
|
||||||
static cell AMX_NATIVE_CALL amx_geoip_code2(AMX *amx, cell *params)
|
static cell AMX_NATIVE_CALL amx_geoip_code2(AMX *amx, cell *params)
|
||||||
{
|
{
|
||||||
int len = 0;
|
int length;
|
||||||
char *ip = MF_GetAmxString(amx, params[1], 0, &len);
|
char *ip = MF_GetAmxString(amx, params[1], 0, &length);
|
||||||
StripPort(ip);
|
|
||||||
const char *ccode = GeoIP_country_code_by_addr(gi, ip);
|
const char *path[] = { "country", "iso_code", NULL };
|
||||||
return MF_SetAmxString(amx, params[2], ccode?ccode:"error", 3);
|
const char *code = lookupByIp(stripPort(ip), path);
|
||||||
|
|
||||||
|
return MF_SetAmxString(amx, params[2], code ? code : "error", 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// native geoip_code3(const ip[], result[4]);
|
||||||
|
// Deprecated.
|
||||||
static cell AMX_NATIVE_CALL amx_geoip_code3(AMX *amx, cell *params)
|
static cell AMX_NATIVE_CALL amx_geoip_code3(AMX *amx, cell *params)
|
||||||
{
|
{
|
||||||
int len = 0;
|
int length;
|
||||||
char *ip = MF_GetAmxString(amx, params[1], 0, &len);
|
char *ip = MF_GetAmxString(amx, params[1], 0, &length);
|
||||||
StripPort(ip);
|
|
||||||
const char *ccode = GeoIP_country_code3_by_addr(gi, ip);
|
const char *path[] = { "country", "iso_code", NULL };
|
||||||
return MF_SetAmxString(amx, params[2], ccode?ccode:"error", 4);
|
const char *code = lookupByIp(stripPort(ip), path);
|
||||||
|
|
||||||
|
for (size_t i = 0; i < ARRAYSIZE(GeoIPCountryCode); ++i)
|
||||||
|
{
|
||||||
|
if (!strncmp(code, GeoIPCountryCode[i], 2))
|
||||||
|
{
|
||||||
|
code = GeoIPCountryCode3[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return MF_SetAmxString(amx, params[2], code ? code : "error", 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// native bool:geoip_code2_ex(const ip[], result[3]);
|
||||||
static cell AMX_NATIVE_CALL amx_geoip_code2_ex(AMX *amx, cell *params)
|
static cell AMX_NATIVE_CALL amx_geoip_code2_ex(AMX *amx, cell *params)
|
||||||
{
|
{
|
||||||
int len = 0;
|
int length;
|
||||||
char *ip = MF_GetAmxString(amx, params[1], 0, &len);
|
char *ip = MF_GetAmxString(amx, params[1], 0, &length);
|
||||||
StripPort(ip);
|
|
||||||
const char *ccode = GeoIP_country_code_by_addr(gi, ip);
|
|
||||||
|
|
||||||
if (ccode == NULL)
|
const char *path[] = { "country", "iso_code", NULL };
|
||||||
|
const char *code = lookupByIp(stripPort(ip), path);
|
||||||
|
|
||||||
|
if (!code)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
MF_SetAmxString(amx, params[2], ccode, 2);
|
MF_SetAmxString(amx, params[2], code, 2);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// native bool:geoip_code3_ex(const ip[], result[4]);
|
||||||
static cell AMX_NATIVE_CALL amx_geoip_code3_ex(AMX *amx, cell *params)
|
static cell AMX_NATIVE_CALL amx_geoip_code3_ex(AMX *amx, cell *params)
|
||||||
{
|
{
|
||||||
int len = 0;
|
int length;
|
||||||
char *ip = MF_GetAmxString(amx, params[1], 0, &len);
|
char *ip = MF_GetAmxString(amx, params[1], 0, &length);
|
||||||
StripPort(ip);
|
|
||||||
const char *ccode = GeoIP_country_code3_by_addr(gi, ip);
|
|
||||||
|
|
||||||
if (ccode == NULL)
|
const char *path[] = { "country", "iso_code", NULL };
|
||||||
|
const char *code = lookupByIp(stripPort(ip), path, &length);
|
||||||
|
|
||||||
|
if (!code)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
MF_SetAmxString(amx, params[2], ccode, 3);
|
for (size_t i = 0; i < ARRAYSIZE(GeoIPCountryCode); ++i)
|
||||||
|
{
|
||||||
|
if (!strncmp(code, GeoIPCountryCode[i], 2))
|
||||||
|
{
|
||||||
|
code = GeoIPCountryCode3[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
MF_SetAmxString(amx, params[2], code, 3);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// native geoip_country(const ip[], result[], len);
|
||||||
static cell AMX_NATIVE_CALL amx_geoip_country(AMX *amx, cell *params)
|
static cell AMX_NATIVE_CALL amx_geoip_country(AMX *amx, cell *params)
|
||||||
{
|
{
|
||||||
int len = 0;
|
int length;
|
||||||
char *ip = MF_GetAmxString(amx, params[1], 0, &len);
|
char *ip = MF_GetAmxString(amx, params[1], 0, &length);
|
||||||
StripPort(ip);
|
|
||||||
const char *ccode = GeoIP_country_name_by_addr(gi, ip);
|
const char *path[] = { "country", "names", "en", NULL };
|
||||||
return MF_SetAmxString(amx, params[2], ccode?ccode:"error", params[3]);
|
const char *country = lookupByIp(stripPort(ip), path, &length);
|
||||||
|
|
||||||
|
return MF_SetAmxString(amx, params[2], country, length >= params[3] ? params[3] : length); // TODO: make this utf8 safe.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void OnAmxxAttach()
|
void OnAmxxAttach()
|
||||||
{
|
{
|
||||||
char *path = MF_BuildPathname("%s/GeoIP.dat",MF_GetLocalInfo("amxx_datadir", "addons/amxmodx/data"));
|
const char *databases[] =
|
||||||
gi = GeoIP_open(path, GEOIP_MEMORY_CACHE);
|
{
|
||||||
if (gi == NULL) {
|
"City",
|
||||||
MF_Log("Failed to instantiate GeoIP!");
|
"Country" // is the default shipped database with AMXX.
|
||||||
|
};
|
||||||
|
|
||||||
|
const char *modName = MF_GetModname();
|
||||||
|
const char *dataDir = MF_GetLocalInfo("amxx_datadir", "addons/amxmodx/data");
|
||||||
|
|
||||||
|
char file[255];
|
||||||
|
int status = -1;
|
||||||
|
|
||||||
|
for (size_t i = 0; i < ARRAYSIZE(databases); ++i)
|
||||||
|
{
|
||||||
|
sprintf(file, "%s/%s/GeoLite2-%s.mmdb", modName, dataDir, databases[i]); // MF_BuildPathname not used because backslash
|
||||||
|
// makes CreateFileMapping failing under windows.
|
||||||
|
status = MMDB_open(file, MMDB_MODE_MMAP, &HandleDB);
|
||||||
|
|
||||||
|
if (status == MMDB_SUCCESS)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else if (status != MMDB_FILE_OPEN_ERROR)
|
||||||
|
{
|
||||||
|
MF_Log("Could not open %s - %s", file, MMDB_strerror(status));
|
||||||
|
|
||||||
|
if (status == MMDB_IO_ERROR)
|
||||||
|
{
|
||||||
|
MF_Log(" IO error: %s", strerror(errno));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status != MMDB_SUCCESS)
|
||||||
|
{
|
||||||
|
MF_Log("Could not find GeoIP2 databases. Disabled natives.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
char *db_info = GeoIP_database_info(gi);
|
|
||||||
MF_Log("Database info: %s", db_info);
|
MF_Log("Database info: %s %i.%i",
|
||||||
|
HandleDB.metadata.description.descriptions[0]->description,
|
||||||
|
HandleDB.metadata.binary_format_major_version,
|
||||||
|
HandleDB.metadata.binary_format_minor_version);
|
||||||
|
|
||||||
MF_AddNatives(geoip_natives);
|
MF_AddNatives(geoip_natives);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OnAmxxDetach()
|
void OnAmxxDetach()
|
||||||
{
|
{
|
||||||
GeoIP_delete(gi);
|
MMDB_close(&HandleDB);
|
||||||
gi = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
AMX_NATIVE_INFO geoip_natives[] = {
|
|
||||||
{"geoip_code2", amx_geoip_code2},
|
|
||||||
{"geoip_code3", amx_geoip_code3},
|
|
||||||
|
|
||||||
{"geoip_code2_ex", amx_geoip_code2_ex},
|
AMX_NATIVE_INFO geoip_natives[] =
|
||||||
{"geoip_code3_ex", amx_geoip_code3_ex},
|
{
|
||||||
|
{ "geoip_code2", amx_geoip_code2 },
|
||||||
|
{ "geoip_code3", amx_geoip_code3 },
|
||||||
|
|
||||||
{"geoip_country", amx_geoip_country},
|
{ "geoip_code2_ex", amx_geoip_code2_ex },
|
||||||
{NULL, NULL},
|
{ "geoip_code3_ex", amx_geoip_code3_ex },
|
||||||
|
|
||||||
|
{ "geoip_country", amx_geoip_country },
|
||||||
|
{ NULL, NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GEOIP2 DATA EXAMPLE:
|
||||||
|
*
|
||||||
|
* {
|
||||||
|
* "city": {
|
||||||
|
* "confidence": 25,
|
||||||
|
* "geoname_id": 54321,
|
||||||
|
* "names": {
|
||||||
|
* "de": "Los Angeles",
|
||||||
|
* "en": "Los Angeles",
|
||||||
|
* "es": "Los Ángeles",
|
||||||
|
* "fr": "Los Angeles",
|
||||||
|
* "ja": "ロサンゼルス市",
|
||||||
|
* "pt-BR": "Los Angeles",
|
||||||
|
* "ru": "Лос-Анджелес",
|
||||||
|
* "zh-CN": "洛杉矶"
|
||||||
|
* }
|
||||||
|
* },
|
||||||
|
* "continent": {
|
||||||
|
* "code": "NA",
|
||||||
|
* "geoname_id": 123456,
|
||||||
|
* "names": {
|
||||||
|
* "de": "Nordamerika",
|
||||||
|
* "en": "North America",
|
||||||
|
* "es": "América del Norte",
|
||||||
|
* "fr": "Amérique du Nord",
|
||||||
|
* "ja": "北アメリカ",
|
||||||
|
* "pt-BR": "América do Norte",
|
||||||
|
* "ru": "Северная Америка",
|
||||||
|
* "zh-CN": "北美洲"
|
||||||
|
*
|
||||||
|
* }
|
||||||
|
* },
|
||||||
|
* "country": {
|
||||||
|
* "confidence": 75,
|
||||||
|
* "geoname_id": "6252001",
|
||||||
|
* "iso_code": "US",
|
||||||
|
* "names": {
|
||||||
|
* "de": "USA",
|
||||||
|
* "en": "United States",
|
||||||
|
* "es": "Estados Unidos",
|
||||||
|
* "fr": "États-Unis",
|
||||||
|
* "ja": "アメリカ合衆国",
|
||||||
|
* "pt-BR": "Estados Unidos",
|
||||||
|
* "ru": "США",
|
||||||
|
* "zh-CN": "美国"
|
||||||
|
* }
|
||||||
|
* },
|
||||||
|
* "location": {
|
||||||
|
* "accuracy_radius": 20,
|
||||||
|
* "latitude": 37.6293,
|
||||||
|
* "longitude": -122.1163,
|
||||||
|
* "metro_code": 807,
|
||||||
|
* "time_zone": "America/Los_Angeles"
|
||||||
|
* },
|
||||||
|
* "postal": {
|
||||||
|
* "code": "90001",
|
||||||
|
* "confidence": 10
|
||||||
|
* },
|
||||||
|
* "registered_country": {
|
||||||
|
* "geoname_id": "6252001",
|
||||||
|
* "iso_code": "US",
|
||||||
|
* "names": {
|
||||||
|
* "de": "USA",
|
||||||
|
* "en": "United States",
|
||||||
|
* "es": "Estados Unidos",
|
||||||
|
* "fr": "États-Unis",
|
||||||
|
* "ja": "アメリカ合衆国",
|
||||||
|
* "pt-BR": "Estados Unidos",
|
||||||
|
* "ru": "США",
|
||||||
|
* "zh-CN": "美国"
|
||||||
|
* }
|
||||||
|
* },
|
||||||
|
* "represented_country": {
|
||||||
|
* "geoname_id": "6252001",
|
||||||
|
* "iso_code": "US",
|
||||||
|
* "names": {
|
||||||
|
* "de": "USA",
|
||||||
|
* "en": "United States",
|
||||||
|
* "es": "Estados Unidos",
|
||||||
|
* "fr": "États-Unis",
|
||||||
|
* "ja": "アメリカ合衆国",
|
||||||
|
* "pt-BR": "Estados Unidos",
|
||||||
|
* "ru": "США",
|
||||||
|
* "zh-CN": "美国"
|
||||||
|
* },
|
||||||
|
* "type": "military"
|
||||||
|
* },
|
||||||
|
* "subdivisions": [
|
||||||
|
* {
|
||||||
|
* "confidence": 50,
|
||||||
|
* "geoname_id": 5332921,
|
||||||
|
* "iso_code": "CA",
|
||||||
|
* "names": {
|
||||||
|
* "de": "Kalifornien",
|
||||||
|
* "en": "California",
|
||||||
|
* "es": "California",
|
||||||
|
* "fr": "Californie",
|
||||||
|
* "ja": "カリフォルニア",
|
||||||
|
* "ru": "Калифорния",
|
||||||
|
* "zh-CN": "加州"
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
* ],
|
||||||
|
* "traits": {
|
||||||
|
* "autonomous_system_number": "1239",
|
||||||
|
* "autonomous_system_organization": "Linkem IR WiMax Network",
|
||||||
|
* "domain": "example.com",
|
||||||
|
* "is_anonymous_proxy": true,
|
||||||
|
* "is_transparent_proxy": true,
|
||||||
|
* "isp": "Linkem spa",
|
||||||
|
* "ip_address": "1.2.3.4",
|
||||||
|
* "organization": "Linkem IR WiMax Network",
|
||||||
|
* "user_type": "traveler",
|
||||||
|
* },
|
||||||
|
* "maxmind": {
|
||||||
|
* "queries_remaining": "54321"
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
@ -14,10 +14,12 @@
|
|||||||
#ifndef _INCLUDE_GEOIPAMXX_H
|
#ifndef _INCLUDE_GEOIPAMXX_H
|
||||||
#define _INCLUDE_GEOIPAMXX_H
|
#define _INCLUDE_GEOIPAMXX_H
|
||||||
|
|
||||||
#define GEOIPDATADIR ""
|
#include "GeoIP2/maxminddb.h"
|
||||||
|
|
||||||
#include "amxxmodule.h"
|
#include "amxxmodule.h"
|
||||||
#include "GeoIP.h"
|
|
||||||
|
#if defined(WIN32)
|
||||||
|
#define snprintf _snprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
extern AMX_NATIVE_INFO geoip_natives[];
|
extern AMX_NATIVE_INFO geoip_natives[];
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@
|
|||||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
<Optimization>Disabled</Optimization>
|
<Optimization>Disabled</Optimization>
|
||||||
<AdditionalIncludeDirectories>..\;..\sdk;..\GeoIP2;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>..\;..\sdk;..\GeoIP2;$(METAMOD)\metamod;$(HLSDK)\common;$(HLSDK)\engine;$(HLSDK)\dlls;$(HLSDK)\pm_shared;$(HLSDK)\public;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;GEOIP_EXPORTS;HAVE_STDINT_H;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;GEOIP_EXPORTS;HAVE_STDINT_H;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<MinimalRebuild>true</MinimalRebuild>
|
<MinimalRebuild>true</MinimalRebuild>
|
||||||
<BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
|
<BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
|
||||||
@ -75,7 +75,7 @@
|
|||||||
</ItemDefinitionGroup>
|
</ItemDefinitionGroup>
|
||||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
<AdditionalIncludeDirectories>..\;..\sdk;..\GeoIP2;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>..\;..\sdk;..\GeoIP2;$(METAMOD)\metamod;$(HLSDK)\common;$(HLSDK)\engine;$(HLSDK)\dlls;$(HLSDK)\pm_shared;$(HLSDK)\public;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;GEOIP_EXPORTS;HAVE_STDINT_H;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;GEOIP_EXPORTS;HAVE_STDINT_H;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
<RuntimeTypeInfo>false</RuntimeTypeInfo>
|
<RuntimeTypeInfo>false</RuntimeTypeInfo>
|
||||||
|
Loading…
Reference in New Issue
Block a user