NAME HTTP::Response::Stringable - Makes HTTP::Response objects stringable VERSION version 0.0001 SYNOPSIS my $res = LWP::UserAgent->new->get('http://example.com'); Role::Tiny->apply_roles_to_object($res, 'HTTP::Response::Stringable'); print "$res"; DESCRIPTION This module is a role that can be applied to HTTP::Response objects to make them stringable. After applying this role to the response object, you can use it in string context. The resulting string will be of the form: $res->status_line . "\n" . $res->content My motivation for creating this module was that I wanted to throw "HTTP::Response" objects as exceptions, and exception objects should have a string representation so that they can be properly logged. Here is an example use case: package WidgetFactory; use Moo; use LWP::UserAgent; sub create_widget { my $res = LWP::UserAgent->new->post('http://widget-factory/widgets'); if (not $res->is_success) { require Role::Tiny; Role::Tiny->apply_roles_to_object($res, 'HTTP::Response::Stringable'); die $res; } } # ... package main; use WidgetFactory; use TryCatch; my $wf = WidgetFactory->new; try { $wf->create_widget(); } catch (HTTP::Response $res) { debug "Creating widget failed: $res"; } AUTHOR Naveed Massjouni <naveed@vt.edu> COPYRIGHT AND LICENSE This software is copyright (c) 2014 by Naveed Massjouni. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.