WebService::RESTCountries - Perl module for using REST Countries (http://restcountries.eu) webservice.
use WebService::RESTCountries;
my $api = WebService::RESTCountries->new;
$api->search_all();
WebService::RESTCountries is a Perl client helper library for the REST Countries API (restcountries.eu).
Source repository at https://github.com/kianmeng/webservice-restcountries.
How to contribute? Follow through the CONTRIBUTING.md document to setup your development environment.
Construct a new WebService::RESTCountries instance. Optionally takes a hash or hash reference.
# Instantiate the class.
my $api = WebService::RESTCountries->new;
The URL of the API resource.
# Instantiate the class by setting the URL of the API endpoints.
my $api = WebService::RESTCountries->new(api_url => 'https://example.com/v2/');
# Set through method.
$api->api_url('https://example.com/v2/');
The cache engine used to cache the web service API calls. By default, it uses file-based caching.
# Instantiate the class by setting the cache engine.
my $api = WebService::RESTCountries->new(
CHI->new(
driver => 'File',
namespace => 'restcountries',
root_dir => $ENV{PWD} . '/tmp/cache/'
)
);
# Set through method.
$api->cache(CHI->new(
driver => 'File',
namespace => 'restcountries',
root_dir => $ENV{PWD} . '/tmp/cache/'
));
Show the country data in specified fields. Do this before making any webservice calls.
# Instantiate the class by setting the selected fields.
my $api = WebService::RESTCountries->new(fields => ['capital', 'currencies', 'name']);
# Set through method.
$api->fields(['capital', 'currencies', 'name']);
my $counties = $api->search_all();
Check whether the API endpoint is currently up.
# Returns 1 if up and 0 otherwise.
$api->ping();
Download the whole countries data as JSON file. Optional path and file name.
# Using default path and file name.
$api->download();
# Using specific path and file name.
$api->download('/tmp/countries.json');
Check whether the API endpoint is currently up.
# Returns 1 if up and 0 otherwise.
$api->ping();
Get all the countries. Basically just pull the whole data in JSON format.
$api->search_all();
Get the details of a country by its calling code, the prefixes for the country phone numbers.
$api->search_by_calling_code('60');
Get the details of a country by its capital city.
# Full name.
$api->search_by_capital_city("Kuala Lumpur");
# Partial name.
$api->search_by_capital_city("Kuala");
Get the details of a country by its ISO 3166 two-letters or three-letters country code.
# Two-letters.
$api->search_by_country_code("MY");
# Three-letters.
$api->search_by_country_code("MYS");
Get the list of country by multiple ISO 3166 two-letters or three-letters country codes.
# Two-letters.
$api->search_by_country_codes(['MY', 'SG']);
# Three-letters.
$api->search_by_country_codes(['MYS', 'SGP']);
Get the details of a country by its full name.
$api->search_by_country_full_name("São Tomé and Príncipe");
Get the details of a country by name, either by native or partial name.
# Native name.
$api->search_by_country_name("Malaysia");
# Partial name.
$api->search_by_country_name("Malays");
Get the details of a country by ISO 4217 currency code.
$api->search_by_currency("MYR");
Get the details of the a country by ISO 639-1 language code.
$api->search_by_language_code("ms");
Get list of country by region: Africa, Americas, Asia, Europe, Oceania. Region name is case insensitive.
$api->search_by_region("Asia");
$api->search_by_region("asia");
Get list of country by regional bloc: EU, EFTA, CARICOM, PA, AU, USAN, EEU, AL, ASEAN, CAIS, CEFTA, NAFTA, SAARC. Regional bloc name is case insensitive.
$api->search_by_region_bloc("EU");
$api->search_by_regional_bloc("asean");
Kian Meng, Ang kianmeng@cpan.org
This software is Copyright (c) 2018 by Kian Meng, Ang.
This is free software, licensed under:
The Artistic License 2.0 (GPL Compatible)