1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
|
package GeoIP2::Error::HTTP;
use strict;
use warnings;
our $VERSION = '2.006002';
use Moo;
use namespace::clean -except => 'meta';
with 'GeoIP2::Role::Error::HTTP';
extends 'Throwable::Error';
1;
# ABSTRACT: An HTTP transport error
__END__
=pod
=encoding UTF-8
=head1 NAME
GeoIP2::Error::HTTP - An HTTP transport error
=head1 VERSION
version 2.006002
=head1 SYNOPSIS
use 5.008;
use GeoIP2::WebService::Client;
use Scalar::Util qw( blessed );
use Try::Tiny;
my $client = GeoIP2::WebService::Client->new(
account_id => 42,
license_key => 'abcdef123456',
);
try {
$client->insights( ip => '24.24.24.24' );
}
catch {
die $_ unless blessed $_;
if ( $_->isa('GeoIP2::Error::HTTP') ) {
log_http_error(
status => $_->http_status(),
uri => $_->uri(),
);
}
# handle other exceptions
};
=head1 DESCRIPTION
This class represents an HTTP transport error. It extends L<Throwable::Error>
and adds attributes of its own.
=head1 METHODS
The C<< $error->message() >>, and C<< $error->stack_trace() >> methods are
inherited from L<Throwable::Error>. It also provide two methods of its own:
=head2 $error->http_status()
Returns the HTTP status. This should be either a 4xx or 5xx error.
=head2 $error->uri()
Returns the URI which gave the HTTP error.
=head1 SUPPORT
Bugs may be submitted through L<https://github.com/maxmind/GeoIP2-perl/issues>.
=head1 AUTHORS
=over 4
=item *
Dave Rolsky <drolsky@maxmind.com>
=item *
Greg Oschwald <goschwald@maxmind.com>
=item *
Mark Fowler <mfowler@maxmind.com>
=item *
Olaf Alders <oalders@maxmind.com>
=back
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2013 - 2019 by MaxMind, Inc.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut
|