mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 19:22:52 -04:00 
			
		
		
		
	* Fixes for tests * add additional fields for company settings * fixes for travis * update company settings schema * Disable client portal * Client Portal middleware * Working on client portal * hide portal * Implement notification channgels for User and ClientContact models * Push notifications onto queue * Force authentication if client portal is password protected
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Mail;
 | |
| 
 | |
| use App\Utils\Ninja;
 | |
| use Illuminate\Bus\Queueable;
 | |
| use Illuminate\Contracts\Queue\ShouldQueue;
 | |
| use Illuminate\Mail\Mailable;
 | |
| use Illuminate\Queue\SerializesModels;
 | |
| 
 | |
| class SupportMessageSent extends Mailable
 | |
| {
 | |
|     use Queueable, SerializesModels;
 | |
| 
 | |
|     public $message;
 | |
| 
 | |
|     public function __construct($message)
 | |
|     {
 | |
|         $this->message = $message;
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Build the message.
 | |
|      *
 | |
|      * @return $this
 | |
|      */
 | |
|     public function build()
 | |
|     {
 | |
|         $system_info = null;
 | |
|         $log_lines = [];
 | |
| 
 | |
|         /**
 | |
|          * With self-hosted version of Ninja,
 | |
|          * we are going to bundle system-level info
 | |
|          * and last 10 lines of laravel.log file.
 | |
|          */
 | |
|         if(Ninja::isSelfHost()) {
 | |
|             $system_info = Ninja::getDebugInfo();
 | |
| 
 | |
|             $log_file = new \SplFileObject(sprintf('%s/laravel.log', base_path('storage/logs')));
 | |
| 
 | |
|             $log_file->seek(PHP_INT_MAX);
 | |
|             $last_line = $log_file->key();
 | |
|             $lines = new \LimitIterator($log_file, $last_line - 10, $last_line);
 | |
| 
 | |
|             $log_lines = iterator_to_array($lines);
 | |
|         }
 | |
| 
 | |
|         return $this->from(config('mail.from.address')) //todo this needs to be fixed to handle the hosted version
 | |
|             ->subject(ctrans('texts.new_support_message'))
 | |
|             ->markdown('email.support.message', [
 | |
|                 'message' => $this->message,
 | |
|                 'system_info' => $system_info,
 | |
|                 'laravel_log' => $log_lines
 | |
|             ]);
 | |
|     }
 | |
| }
 | |
| 
 |