Adds local cache, doesn't check reconnects, fixes bugs

This commit is contained in:
MrStonedOne
2016-05-11 23:40:37 -07:00
parent 2523a0d604
commit c37ae784e7
7 changed files with 76 additions and 22 deletions

View File

@@ -1,3 +1,16 @@
16th April 2016
Added ipintel table, only required if ip intel is enabled in the config
CREATE TABLE `ipintel` (
`ip` INT UNSIGNED NOT NULL ,
`date` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NOT NULL ,
`intel` REAL NOT NULL DEFAULT '0',
PRIMARY KEY ( `ip` )
) ENGINE = INNODB;
---------------------------------------------------
21 September 2015, by Jordie0608 21 September 2015, by Jordie0608
Modified table 'poll_question', adding columns 'createdby_ckey', 'createdby_ip' and 'for_trialmin' to bring it inline with the schema used by the tg servers. Modified table 'poll_question', adding columns 'createdby_ckey', 'createdby_ip' and 'for_trialmin' to bring it inline with the schema used by the tg servers.

View File

@@ -369,7 +369,7 @@ DROP TABLE IF EXISTS `ipintel`;
/*!40101 SET character_set_client = utf8 */; /*!40101 SET character_set_client = utf8 */;
CREATE TABLE `ipintel` ( CREATE TABLE `ipintel` (
`ip` INT UNSIGNED NOT NULL , `ip` INT UNSIGNED NOT NULL ,
`date` TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NOT NULL , `date` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NOT NULL ,
`intel` REAL NOT NULL DEFAULT '0', `intel` REAL NOT NULL DEFAULT '0',
PRIMARY KEY ( `ip` ) PRIMARY KEY ( `ip` )
) ENGINE = INNODB; ) ENGINE = INNODB;

View File

@@ -364,9 +364,9 @@ DROP TABLE IF EXISTS `SS13_ipintel`;
/*!40101 SET character_set_client = utf8 */; /*!40101 SET character_set_client = utf8 */;
CREATE TABLE `SS13_ipintel` ( CREATE TABLE `SS13_ipintel` (
`ip` INT UNSIGNED NOT NULL , `ip` INT UNSIGNED NOT NULL ,
`date` TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NOT NULL , `date` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NOT NULL ,
`intel` REAL NOT NULL DEFAULT '0', `intel` REAL NOT NULL DEFAULT '0',
PRIMARY KEY ( `ip` ) PRIMARY KEY ( `ip` )
) ENGINE = INNODB; ) ENGINE = INNODB;
/*!40101 SET character_set_client = @saved_cs_client */;
-- Dump completed on 2013-03-24 18:02:35 -- Dump completed on 2013-03-24 18:02:35

View File

@@ -0,0 +1,18 @@
var/datum/subsystem/ipintel/SSipintel
/datum/subsystem/ipintel
name = "IP Intel"
priority = -3
var/enabled = 0 //disable at round start to avoid checking reconnects
var/throttle = 0
var/errors = 0
var/list/cache = list()
/datum/subsystem/ipintel/New()
NEW_SS_GLOBAL(SSipintel)
/datum/subsystem/ipintel/Initialize(timeofday, zlevel)
enabled = 1
. = ..()

View File

@@ -99,7 +99,7 @@
log_access("Failed Login: [key] [computer_id] [address] - Banned [.["reason"]]") log_access("Failed Login: [key] [computer_id] [address] - Banned [.["reason"]]")
return . return .
if (config.ipintel_email) if (config.ipintel_email && SSipintel.enabled)
var/datum/ipintel/res = get_ip_intel(address) var/datum/ipintel/res = get_ip_intel(address)
if (res.intel > config.ipintel_rating_max) if (res.intel > config.ipintel_rating_max)
if (admin) if (admin)

View File

@@ -4,39 +4,61 @@
var/cache = FALSE var/cache = FALSE
var/cacheminutesago = 0 var/cacheminutesago = 0
var/cachedate = "" var/cachedate = ""
var/cacherealtime = 0
/datum/ipintel/New() /datum/ipintel/New()
cachedate = SQLtime() cachedate = SQLtime()
cacherealtime = world.realtime
/datum/ipintel/proc/is_valid()
. = FALSE
if (intel < 0)
return
if (intel <= config.ipintel_rating_max)
if (world.realtime < cacherealtime+(config.ipintel_save_good*60*60*10))
return TRUE
else
if (world.realtime < cacherealtime+(config.ipintel_save_bad*60*60*10))
return TRUE
/proc/get_ip_intel(ip, bypasscache = FALSE, updatecache = TRUE) /proc/get_ip_intel(ip, bypasscache = FALSE, updatecache = TRUE)
var/datum/ipintel/res = new() var/datum/ipintel/res = new()
res.ip = ip res.ip = ip
. = res . = res
if (!ip || !config.ipintel_email) if (!ip || !config.ipintel_email || !SSipintel.enabled)
return return
if (!bypasscache && establish_db_connection()) if (!bypasscache)
var/DBQuery/query = dbcon.NewQuery("SELECT date,intel,TIMESTAMPDIFF(MINUTE,date,NOW()) FROM [format_table_name("ipintel")] WHERE ip = INET_ATON('[ip]') AND ((intel <= [config.ipintel_rating_max] AND date + INTERVAL [config.ipintel_save_good] HOUR > NOW()) OR (intel > [config.ipintel_rating_max] AND date + INTERVAL [config.ipintel_save_bad] HOUR > NOW()))") var/datum/ipintel/cachedintel = SSipintel.cache[ip]
query.Execute() if (cachedintel && cachedintel.is_valid())
if (query.NextRow()) cachedintel.cache = TRUE
res.cache = TRUE return cachedintel
res.cachedate = query.item[1]
res.intel = query.item[2] if (establish_db_connection())
res.cacheminutesago = query.item[3] var/DBQuery/query = dbcon.NewQuery("SELECT date, intel, TIMESTAMPDIFF(MINUTE,date,NOW()), UNIX_TIMESTAMP(date) FROM [format_table_name("ipintel")] WHERE ip = INET_ATON('[ip]') AND ((intel <= [config.ipintel_rating_max] AND date + INTERVAL [config.ipintel_save_good] HOUR > NOW()) OR (intel > [config.ipintel_rating_max] AND date + INTERVAL [config.ipintel_save_bad] HOUR > NOW()))")
return query.Execute()
if (query.NextRow())
res.cache = TRUE
res.cachedate = query.item[1]
res.intel = query.item[2]
res.cacheminutesago = query.item[3]
res.cacherealtime = query.item[4]*10
SSipintel.cache[ip] = res
return
res.intel = ip_intel_query(ip) res.intel = ip_intel_query(ip)
if (updatecache && res.intel >= 0 && establish_db_connection()) if (updatecache && res.intel >= 0 && establish_db_connection())
//if you're wondering, we don't add or update the date as its a TIMESTAMP field, and as such, automatically updates at any insert or update SSipintel.cache[ip] = res
var/DBQuery/query = dbcon.NewQuery("INSERT INTO [format_table_name("ipintel")] (ip, intel) VALUES (INET_ATON('[ip]'), [res.intel]) ON DUPLICATE KEY UPDATE intel = VALUES(intel)") var/DBQuery/query = dbcon.NewQuery("INSERT INTO [format_table_name("ipintel")] (ip, intel) VALUES (INET_ATON('[ip]'), [res.intel]) ON DUPLICATE KEY UPDATE intel = VALUES(intel), date = NULL")
query.Execute() query.Execute()
return return
var/ip_intel_throttle = 0
var/ip_intel_errors = 0
/proc/ip_intel_query(ip, var/retry=0) /proc/ip_intel_query(ip, var/retry=0)
. = -1 //default . = -1 //default
if (!ip) if (!ip)
return return
if (ip_intel_throttle > world.timeofday) if (SSipintel.throttle > world.timeofday)
return return
var/http[] = world.Export("http://check.getipintel.net/check.php?ip=[ip]&contact=[config.ipintel_email]&format=json") var/http[] = world.Export("http://check.getipintel.net/check.php?ip=[ip]&contact=[config.ipintel_email]&format=json")
@@ -72,9 +94,9 @@ var/ip_intel_errors = 0
/proc/ipintel_handle_error(error, ip, retry) /proc/ipintel_handle_error(error, ip, retry)
if (retry) if (retry)
ip_intel_errors++ SSipintel.errors++
error += " Could not check [ip]. Disabling IPINTEL for [ip_intel_errors] minute[( ip_intel_errors == 1 ? "" : "s" )]" error += " Could not check [ip]. Disabling IPINTEL for [SSipintel.errors] minute[( SSipintel.errors == 1 ? "" : "s" )]"
ip_intel_throttle = world.timeofday + (10 * 60 * ip_intel_errors) SSipintel.throttle = world.timeofday + (10 * 60 * SSipintel.errors)
else else
error += " Attempting retry on [ip]." error += " Attempting retry on [ip]."
log_ipintel(error) log_ipintel(error)

View File

@@ -136,6 +136,7 @@
#include "code\controllers\subsystem\fastprocess.dm" #include "code\controllers\subsystem\fastprocess.dm"
#include "code\controllers\subsystem\garbage.dm" #include "code\controllers\subsystem\garbage.dm"
#include "code\controllers\subsystem\icon_smooth.dm" #include "code\controllers\subsystem\icon_smooth.dm"
#include "code\controllers\subsystem\ipintel.dm"
#include "code\controllers\subsystem\jobs.dm" #include "code\controllers\subsystem\jobs.dm"
#include "code\controllers\subsystem\lighting.dm" #include "code\controllers\subsystem\lighting.dm"
#include "code\controllers\subsystem\machines.dm" #include "code\controllers\subsystem\machines.dm"