mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 05:26:17 +00:00 
			
		
		
		
	Use a job to send the error email instead of inline. #196
This commit is contained in:
		
							
								
								
									
										93
									
								
								app/Jobs/MailError.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								app/Jobs/MailError.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| <?php | ||||
|  | ||||
| namespace FireflyIII\Jobs; | ||||
|  | ||||
| use ErrorException; | ||||
| use FireflyIII\User; | ||||
| use Illuminate\Contracts\Queue\ShouldQueue; | ||||
| use Illuminate\Mail\Message; | ||||
| use Illuminate\Queue\InteractsWithQueue; | ||||
| use Illuminate\Queue\SerializesModels; | ||||
| use Log; | ||||
| use Mail; | ||||
| use Swift_TransportException; | ||||
|  | ||||
| /** | ||||
|  * Class MailError | ||||
|  * | ||||
|  * @package FireflyIII\Jobs | ||||
|  */ | ||||
| class MailError extends Job implements ShouldQueue | ||||
| { | ||||
|     use InteractsWithQueue, SerializesModels; | ||||
|  | ||||
|     /** @var  string */ | ||||
|     protected $destination; | ||||
|     /** @var  array */ | ||||
|     protected $exception; | ||||
|     /** @var  string */ | ||||
|     protected $ip; | ||||
|     /** @var  User */ | ||||
|     protected $user; | ||||
|  | ||||
|     /** | ||||
|      * MailError constructor. | ||||
|      * | ||||
|      * @param User   $user | ||||
|      * @param string $destination | ||||
|      * @param string $ip | ||||
|      * @param array  $exception | ||||
|      */ | ||||
|     public function __construct(User $user, string $destination, string $ip, array $exceptionData) | ||||
|     { | ||||
|         $this->user        = $user; | ||||
|         $this->destination = $destination; | ||||
|         $this->ip          = $ip; | ||||
|         $this->exception   = $exceptionData; | ||||
|  | ||||
|         Log::debug('In mail job constructor'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Execute the job. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function handle() | ||||
|     { | ||||
|         Log::debug('Start of handle()'); | ||||
|         if ($this->attempts() < 3) { | ||||
|             // mail? | ||||
|             try { | ||||
|                 $email = env('SITE_OWNER'); | ||||
|                 $args  = [ | ||||
|                     'class'        => $this->exception['class'], | ||||
|                     'errorMessage' => $this->exception['errorMessage'], | ||||
|                     'stacktrace'   => $this->exception['stackTrace'], | ||||
|                     'file'         => $this->exception['file'], | ||||
|                     'line'         => $this->exception['line'], | ||||
|                     'code'         => $this->exception['code'], | ||||
|                     'loggedIn'     => !is_null($this->user->id), | ||||
|                     'user'         => $this->user, | ||||
|                     'ip'           => $this->ip, | ||||
|  | ||||
|                 ]; | ||||
|  | ||||
|                 Mail::send( | ||||
|                     ['emails.error-html', 'emails.error'], $args, | ||||
|                     function (Message $message) use ($email) { | ||||
|                         if ($email != 'mail@example.com') { | ||||
|                             $message->to($email, $email)->subject('Caught an error in Firely III.'); | ||||
|                         } | ||||
|                     } | ||||
|                 ); | ||||
|             } catch (Swift_TransportException $e) { | ||||
|                 // could also not mail! :o | ||||
|                 Log::error('Swift Transport Exception' . $e->getMessage()); | ||||
|             } catch (ErrorException $e) { | ||||
|                 Log::error('ErrorException ' . $e->getMessage()); | ||||
|             } | ||||
|             Log::debug('Successfully handled error.'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user