]> git.ipfire.org Git - ipfire-2.x.git/commitdiff
location-functions.pl: Refactor get_full_country_name() function to use the Location...
authorStefan Schantl <stefan.schantl@ipfire.org>
Tue, 22 Sep 2020 18:25:00 +0000 (20:25 +0200)
committerMichael Tremer <michael.tremer@ipfire.org>
Thu, 24 Sep 2020 17:36:38 +0000 (17:36 +0000)
Signed-off-by: Stefan Schantl <stefan.schantl@ipfire.org>
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
config/cfgroot/location-functions.pl

index a94d5909e1104a19d7ca312f3ee0e197a632df14..c8ccd94c2ee8a4733fb4f197f8b022e0a8494f3f 100644 (file)
 package Location::Functions;
 
 use Location;
-use Locale::Codes::Country;
 
 # Hash which contains country codes and their names which are special or not
 # part of ISO 3166-1.
 my %not_iso_3166_location = (
-       "a1" => "Anonymous Proxy",
-       "a2" => "Satellite Provider",
-       "a3" => "Worldwide Anycast Instance",
-       "an" => "Netherlands Antilles",
-       "ap" => "Asia/Pacific Region",
-       "eu" => "Europe",
-       "fx" => "France, Metropolitan"
+       "A1" => "Anonymous Proxy",
+       "A2" => "Satellite Provider",
+       "A3" => "Worldwide Anycast Instance",
 );
 
 # Array which contains special country codes.
@@ -152,17 +147,19 @@ sub get_full_country_name($) {
        # Remove whitespaces.
        chomp($input);
 
+       # Convert input into upper case format.
+       my $code = uc($input);
 
-       # Convert input into lower case format.
-       my $code = lc($input);
-
-       # Handle country codes which are not in the list.
+       # Handle country codes which are special or not part of the list.
        if ($not_iso_3166_location{$code}) {
                # Grab location name from hash.
                $name = $not_iso_3166_location{$code};
        } else {
-               # Use perl built-in module to get the country code.
-               $name = &Locale::Codes::Country::code2country($code);
+               # Init libloc database connection.
+               my $db_handle = &init();
+
+               # Get the country name by using the location module.
+               $name = &Location::get_country_name($db_handle, $code);
        }
 
        return $name;