NAME
WebService::IFConfig::Client - Client for Martin Polden's https://ifconfig.co
SYNOPSIS
use strict;
use warnings;
use 5.12.0;
use feature qw/say/;
use WebService::IFConfig::Client;
my $ifconfig = WebService::IFConfig::Client->new();
say $ifconfig->get_city;
say $ifconfig->get_country;
say $ifconfig->get_hostname;
say $ifconfig->get_ip;
say $ifconfig->get_ip_decimal;
# Time passes ...
# Request again
$ifconfig->request;
Calling new()
with no arguments, defaults to requesting immediately from https://ifconfig.co.
To defer requesting, the data you can pass the argument 'run' => 0
.
To use a different server, pass 'server' => $my_server
.
METHODS
WebService::IFConfig::Client->new( 'run' => $boolean , 'server' => $my_server );
Constructor to create an new client. Default values are
Argument Default Meaning
-------- ------- -------
run 1 1 means run immediately.
0 means do not run until a request is made.
server https://ifconfig.co/json IPD Server, but you can run your own and provide it here.
get_server
Get the URL this client is configured to talk to
set_server
Set the URL this client is configured to talk to
get_raw_status
Get the HTTP Response Code of the latest request. Returns 0 if no request has been made.
get_status
Returns 1 if the HTTP Response Code of the latest request was 200, or 0 if not. Returns undef if no request has been made.
request
Makes a(nother) request from the server.
get_city
Get the City name. Forces a request if no valid data.
get_country
Get the Country name. Forces a request if no valid data.
get_hostname
Get the Hostname. Forces a request if no valid data.
get_ip
Get the IP address. Forces a request if no valid data.
get_ip_decimal
Get a decimal representation of the IP. Forces a request if no valid data.
AUTHOR
Nic Doye <nic@worldofnic.org>
BUGS
None. None whatsoever. (This is a lie).
LICENSE
Copyright 2017 Nicolas Doye
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.