diff --git a/inc/config.php b/inc/config.php index 4ffff767..1dbec895 100644 --- a/inc/config.php +++ b/inc/config.php @@ -773,9 +773,14 @@ // $config['board_path'] if you wish to change the URL. $config['board_abbreviation'] = '/%s/'; - // The default name (ie. Anonymous). Can be an array - in that case it's picked randomly from the array. + // The default name (e.g. Anonymous). Can be an array - in that case it's picked randomly from the array. // Example: $config['anonymous'] = array('Bernd', 'Senpai', 'Jonne', 'ChanPro'); $config['anonymous'] = 'Anonymous'; + // Pick the default name based on the poster's country. Can contain subarrays and is picked randomly from the them. + // If the user posts from a country you have not set a name for, his name is going to be whatever you set in $config['anonymous']. + // Example 1: $config['country_anonymous'] = array('cz' => 'Pepik', 'pl' => 'Karol Wojtyla', 'de' => 'Bernd', 'fi' => 'Jonne'); + // Example 2: $config['country_anonymous'] = array('cz' => array('Pepik', 'Bohus', 'Lada'), 'pl' => array('Karol Wojtyla', 'Demon Pedofyl'); + $config['country_anonymous'] = false; // Number of reports you can create at once. $config['report_limit'] = 3; diff --git a/inc/functions.php b/inc/functions.php index 6ce76472..4313e531 100644 --- a/inc/functions.php +++ b/inc/functions.php @@ -21,6 +21,8 @@ require_once 'inc/api.php'; require_once 'inc/bans.php'; require_once 'inc/lib/gettext/gettext.inc'; +use Lifo\IP\IP; + // the user is not currently logged in as a moderator $mod = false; @@ -242,6 +244,23 @@ function loadConfig() { if (is_array($config['anonymous'])) $config['anonymous'] = $config['anonymous'][array_rand($config['anonymous'])]; + + if ($config['country_flags'] || $config['country_anonymous']) { + require_once 'inc/lib/geoip/geoip.inc'; + $gi=geoip_open('inc/lib/geoip/GeoIPv6.dat', GEOIP_STANDARD); + $ipaddy = $_SERVER['REMOTE_ADDR']; + if (IP::isIPv4($ipaddy)) + $ipaddy = IP::to_ipv6($ipaddy, true); + global $country_code, $country_name; + $country_code = strtolower(geoip_country_code_by_addr_v6($gi, $ipaddy)); + $country_name = geoip_country_name_by_addr_v6($gi, $ipaddy); + if (isset($config['country_anonymous'][$country_code])) { + if (is_array($config['country_anonymous'][$country_code])) + $config['anonymous'] = $config['country_anonymous'][$country_code][array_rand($config['country_anonymous'][$country_code])]; + else + $config['anonymous'] = $config['country_anonymous'][$country_code]; + } + } event('load-config'); diff --git a/post.php b/post.php index d1c2b086..dbd35e64 100644 --- a/post.php +++ b/post.php @@ -488,26 +488,8 @@ if (isset($_POST['delete'])) { } if ($config['country_flags']) { - require 'inc/lib/geoip/geoip.inc'; - $gi=geoip\geoip_open('inc/lib/geoip/GeoIPv6.dat', GEOIP_STANDARD); - - function ipv4to6($ip) { - if (strpos($ip, ':') !== false) { - if (strpos($ip, '.') > 0) - $ip = substr($ip, strrpos($ip, ':')+1); - else return $ip; //native ipv6 - } - $iparr = array_pad(explode('.', $ip), 4, 0); - $part7 = base_convert(($iparr[0] * 256) + $iparr[1], 10, 16); - $part8 = base_convert(($iparr[2] * 256) + $iparr[3], 10, 16); - return '::ffff:'.$part7.':'.$part8; - } - - if ($country_code = geoip\geoip_country_code_by_addr_v6($gi, ipv4to6($_SERVER['REMOTE_ADDR']))) { - if (!in_array(strtolower($country_code), array('eu', 'ap', 'o1', 'a1', 'a2'))) - $post['body'] .= "\n".strtolower($country_code)."". - "\n".geoip\geoip_country_name_by_addr_v6($gi, ipv4to6($_SERVER['REMOTE_ADDR'])).""; - } + if (!in_array($country_code, array('eu', 'ap', 'o1', 'a1', 'a2'))) + $post['body'] .= "\n".$country_code."\n".$country_name.""; } if ($config['user_flag'] && isset($_POST['user_flag']))