Bug 25032: Generic unhandled exception handling on API
[koha.git] / Koha / REST / Plugin / Exceptions.pm
blob4539b847aaa46541baf92cdb462632d35a58df7d
1 package Koha::REST::Plugin::Exceptions;
3 # This file is part of Koha.
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
18 use Modern::Perl;
20 use Scalar::Util qw( blessed );
21 use Koha::Logger;
23 use Mojo::Base 'Mojolicious::Plugin';
25 =head1 NAME
27 Koha::REST::Plugin::Exceptions
29 =head1 API
31 =head2 Helper methods
33 =head3 unhandled_exception
35 try {
36 ...
38 catch {
39 if ( know_exception ) {
40 handle_known_exception($_);
43 $c->unhandled_exception($_);
46 Provides a generic and reusable way to throw unhandled exceptions. This way we
47 can centralize the behaviour control (e.g. production vs. development environmet)
49 =cut
51 sub register {
52 my ( $self, $app ) = @_;
54 $app->helper(
55 'unhandled_exception' => sub {
56 my ( $c, $exception ) = @_;
58 my $req = $c->req;
59 my $method = $req->method;
60 my $path = $req->url->to_abs->path;
61 my $type = "";
63 if ( blessed $exception ) {
64 $type = "(" . ref($exception) . ")";
67 my $message = "$method $path: unhandled exception $type\<\<$exception\>\>";
69 $c->app->log->error("$message");
71 $c->render(
72 status => 500,
73 openapi => {
74 error =>
75 "Something went wrong, check Koha logs for details."