diff --git a/inc/config.php b/inc/config.php index 1dbec895..4ffff767 100644 --- a/inc/config.php +++ b/inc/config.php @@ -773,14 +773,9 @@ // $config['board_path'] if you wish to change the URL. $config['board_abbreviation'] = '/%s/'; - // The default name (e.g. Anonymous). Can be an array - in that case it's picked randomly from the array. + // The default name (ie. 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 4313e531..6ce76472 100644 --- a/inc/functions.php +++ b/inc/functions.php @@ -21,8 +21,6 @@ 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; @@ -244,23 +242,6 @@ 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 dbef412e..d6dfdaa1 100644 --- a/post.php +++ b/post.php @@ -488,8 +488,26 @@ if (isset($_POST['delete'])) { } if ($config['country_flags']) { - if (!in_array($country_code, array('eu', 'ap', 'o1', 'a1', 'a2'))) - $post['body'] .= "\n".$country_code."\n".$country_name.""; + 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 ($config['user_flag'] && isset($_POST['user_flag']))