| 
									
										
										
										
											2016-01-08 16:02:15 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2018-05-11 10:08:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Handler.php | 
					
						
							| 
									
										
										
										
											2020-01-28 08:44:57 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-14 17:40:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-06 07:37:14 +02:00
										 |  |  | /** @noinspection MultipleReturnStatementsInspection */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-11 10:08:34 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-08 16:02:15 +01:00
										 |  |  | namespace FireflyIII\Exceptions; | 
					
						
							| 
									
										
										
										
											2015-02-06 04:39:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  | use ErrorException; | 
					
						
							| 
									
										
										
										
											2015-02-06 04:39:52 +01:00
										 |  |  | use Exception; | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  | use FireflyIII\Jobs\MailError; | 
					
						
							| 
									
										
										
										
											2018-02-17 14:14:26 +01:00
										 |  |  | use Illuminate\Auth\AuthenticationException; | 
					
						
							| 
									
										
										
										
											2016-01-08 16:02:15 +01:00
										 |  |  | use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler; | 
					
						
							| 
									
										
										
										
											2020-07-31 12:45:02 +02:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							| 
									
										
										
										
											2018-07-15 10:00:08 +02:00
										 |  |  | use Illuminate\Validation\ValidationException as LaravelValidationException; | 
					
						
							| 
									
										
										
										
											2018-05-10 09:48:13 +02:00
										 |  |  | use League\OAuth2\Server\Exception\OAuthServerException; | 
					
						
							| 
									
										
										
										
											2021-04-03 12:25:35 +02:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2018-02-10 09:57:56 +01:00
										 |  |  | use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | 
					
						
							| 
									
										
										
										
											2020-06-06 22:25:52 +02:00
										 |  |  | use Throwable; | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 14:30:53 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class Handler | 
					
						
							| 
									
										
										
										
											2018-12-15 07:59:02 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-08-23 18:33:07 +02:00
										 |  |  |  * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2017-12-17 14:30:53 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  | class Handler extends ExceptionHandler | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-04-03 12:25:35 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @var array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $dontReport | 
					
						
							|  |  |  |         = [ | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 14:17:11 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  |      * Render an exception into an HTTP response. | 
					
						
							| 
									
										
										
										
											2016-02-11 14:17:11 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-06 07:37:14 +02:00
										 |  |  |      * @param Request   $request | 
					
						
							|  |  |  |      * @param Exception $exception | 
					
						
							| 
									
										
										
										
											2019-08-17 10:46:55 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-06 07:37:14 +02:00
										 |  |  |      * @return mixed | 
					
						
							| 
									
										
										
										
											2016-02-11 14:17:11 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-06-06 22:25:52 +02:00
										 |  |  |     public function render($request, Throwable $exception) | 
					
						
							| 
									
										
										
										
											2016-02-11 14:17:11 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-15 10:00:08 +02:00
										 |  |  |         if ($exception instanceof LaravelValidationException && $request->expectsJson()) { | 
					
						
							| 
									
										
										
										
											2018-02-13 18:24:06 +01:00
										 |  |  |             // ignore it: controller will handle it.
 | 
					
						
							|  |  |  |             return parent::render($request, $exception); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-02-10 09:57:56 +01:00
										 |  |  |         if ($exception instanceof NotFoundHttpException && $request->expectsJson()) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:51:51 +01:00
										 |  |  |             // JSON error:
 | 
					
						
							| 
									
										
										
										
											2018-02-11 20:45:33 +01:00
										 |  |  |             return response()->json(['message' => 'Resource not found', 'exception' => 'NotFoundHttpException'], 404); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-02-17 14:14:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($exception instanceof AuthenticationException && $request->expectsJson()) { | 
					
						
							| 
									
										
										
										
											2018-03-07 05:51:51 +01:00
										 |  |  |             // somehow Laravel handler does not catch this:
 | 
					
						
							| 
									
										
										
										
											2018-02-17 14:14:26 +01:00
										 |  |  |             return response()->json(['message' => 'Unauthenticated', 'exception' => 'AuthenticationException'], 401); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-10 09:48:13 +02:00
										 |  |  |         if ($exception instanceof OAuthServerException && $request->expectsJson()) { | 
					
						
							|  |  |  |             // somehow Laravel handler does not catch this:
 | 
					
						
							|  |  |  |             return response()->json(['message' => $exception->getMessage(), 'exception' => 'OAuthServerException'], 401); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-11 20:45:33 +01:00
										 |  |  |         if ($request->expectsJson()) { | 
					
						
							| 
									
										
										
										
											2018-03-04 08:22:32 +01:00
										 |  |  |             $isDebug = config('app.debug', false); | 
					
						
							| 
									
										
										
										
											2018-02-11 20:45:33 +01:00
										 |  |  |             if ($isDebug) { | 
					
						
							|  |  |  |                 return response()->json( | 
					
						
							|  |  |  |                     [ | 
					
						
							|  |  |  |                         'message'   => $exception->getMessage(), | 
					
						
							| 
									
										
										
										
											2019-06-07 18:13:54 +02:00
										 |  |  |                         'exception' => get_class($exception), | 
					
						
							| 
									
										
										
										
											2018-02-11 20:45:33 +01:00
										 |  |  |                         'line'      => $exception->getLine(), | 
					
						
							|  |  |  |                         'file'      => $exception->getFile(), | 
					
						
							|  |  |  |                         'trace'     => $exception->getTrace(), | 
					
						
							| 
									
										
										
										
											2020-03-17 14:57:04 +01:00
										 |  |  |                     ], | 
					
						
							|  |  |  |                     500 | 
					
						
							| 
									
										
										
										
											2018-02-11 20:45:33 +01:00
										 |  |  |                 ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |             return response()->json( | 
					
						
							|  |  |  |                 ['message' => sprintf('Internal Firefly III Exception: %s', $exception->getMessage()), 'exception' => get_class($exception)], 500 | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2018-02-10 09:57:56 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-17 14:57:04 +01:00
										 |  |  |         if ($exception instanceof NotFoundHttpException) { | 
					
						
							| 
									
										
										
										
											2019-08-01 06:22:07 +02:00
										 |  |  |             $handler = app(GracefulNotFoundHandler::class); | 
					
						
							| 
									
										
										
										
											2020-03-17 14:57:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-01 06:22:07 +02:00
										 |  |  |             return $handler->render($request, $exception); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-05-10 09:48:13 +02:00
										 |  |  |         if ($exception instanceof FireflyException || $exception instanceof ErrorException || $exception instanceof OAuthServerException) { | 
					
						
							| 
									
										
										
										
											2018-12-15 07:59:02 +01:00
										 |  |  |             $isDebug = config('app.debug'); | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             return response()->view('errors.FireflyException', ['exception' => $exception, 'debug' => $isDebug], 500); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return parent::render($request, $exception); | 
					
						
							| 
									
										
										
										
											2015-02-11 07:35:10 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-16 06:40:45 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  |      * Report or log an exception. | 
					
						
							| 
									
										
										
										
											2016-10-07 05:44:21 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-06-07 18:13:54 +02:00
										 |  |  |      * This is a great spot to send exceptions to Sentry etc. | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-08-17 10:46:55 +02:00
										 |  |  |      *  // it's five its fine.
 | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-04-03 12:25:35 +02:00
										 |  |  |      * @param Throwable $e | 
					
						
							| 
									
										
										
										
											2017-11-18 05:46:19 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |      * @return void | 
					
						
							| 
									
										
										
										
											2020-03-17 14:57:04 +01:00
										 |  |  |      * @throws Exception | 
					
						
							| 
									
										
										
										
											2017-12-22 18:32:43 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-09-16 06:40:45 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-04-03 12:25:35 +02:00
										 |  |  |     public function report(Throwable $e) | 
					
						
							| 
									
										
										
										
											2016-09-16 06:40:45 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-12-15 07:59:02 +01:00
										 |  |  |         $doMailError = config('firefly.send_error_message'); | 
					
						
							| 
									
										
										
										
											2021-04-03 12:25:35 +02:00
										 |  |  |         if ($this->shouldntReport($e) || !$doMailError) { | 
					
						
							|  |  |  |             Log::info('Will not report on this error.'); | 
					
						
							|  |  |  |             parent::report($e); | 
					
						
							|  |  |  |             return; | 
					
						
							| 
									
										
										
										
											2017-09-12 22:14:43 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-04-03 12:25:35 +02:00
										 |  |  |         $userData = [ | 
					
						
							|  |  |  |             'id'    => 0, | 
					
						
							|  |  |  |             'email' => 'unknown@example.com', | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         if (auth()->check()) { | 
					
						
							|  |  |  |             $userData['id']    = auth()->user()->id; | 
					
						
							|  |  |  |             $userData['email'] = auth()->user()->email; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'class'        => get_class($e), | 
					
						
							|  |  |  |             'errorMessage' => $e->getMessage(), | 
					
						
							|  |  |  |             'time'         => date('r'), | 
					
						
							|  |  |  |             'stackTrace'   => $e->getTraceAsString(), | 
					
						
							|  |  |  |             'file'         => $e->getFile(), | 
					
						
							|  |  |  |             'line'         => $e->getLine(), | 
					
						
							|  |  |  |             'code'         => $e->getCode(), | 
					
						
							|  |  |  |             'version'      => config('firefly.version'), | 
					
						
							|  |  |  |             'url'          => request()->fullUrl(), | 
					
						
							|  |  |  |             'userAgent'    => request()->userAgent(), | 
					
						
							|  |  |  |             'json'         => request()->acceptsJson(), | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // create job that will mail.
 | 
					
						
							|  |  |  |         $ipAddress = request()->ip() ?? '0.0.0.0'; | 
					
						
							|  |  |  |         $job       = new MailError($userData, (string)config('firefly.site_owner'), $ipAddress, $data); | 
					
						
							|  |  |  |         dispatch($job); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         parent::report($e); | 
					
						
							| 
									
										
										
										
											2016-09-16 06:40:45 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-02-06 04:39:52 +01:00
										 |  |  | } |