mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-11-03 23:57:33 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			87 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Mail;
 | 
						|
 | 
						|
use App\Utils\Ninja;
 | 
						|
use Illuminate\Bus\Queueable;
 | 
						|
use Illuminate\Mail\Mailable;
 | 
						|
use Illuminate\Queue\SerializesModels;
 | 
						|
use LimitIterator;
 | 
						|
use SplFileObject;
 | 
						|
 | 
						|
class SupportMessageSent extends Mailable
 | 
						|
{
 | 
						|
 //   use Queueable, SerializesModels;
 | 
						|
 | 
						|
    public $data;
 | 
						|
 | 
						|
    public $send_logs;
 | 
						|
 | 
						|
    public function __construct(array $data, $send_logs)
 | 
						|
    {
 | 
						|
        $this->data = $data;
 | 
						|
        $this->send_logs = $send_logs;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 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() && $this->send_logs !== false) {
 | 
						|
            $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 - 100, $last_line);
 | 
						|
            $log_lines = iterator_to_array($lines);
 | 
						|
        }
 | 
						|
 | 
						|
        $account = auth()->user()->account;
 | 
						|
 | 
						|
        $priority = '';
 | 
						|
        $plan = $account->plan ?: 'customer support';
 | 
						|
        $plan = ucfirst($plan);
 | 
						|
 | 
						|
        if(strlen($account->plan) > 1)
 | 
						|
            $priority = '[PRIORITY] ';
 | 
						|
 | 
						|
        $company = auth()->user()->company();
 | 
						|
        $user = auth()->user();
 | 
						|
        $db = str_replace("db-ninja-", "", $company->db);
 | 
						|
        $is_large = $company->is_large ? "L" : "S";
 | 
						|
        $platform = array_key_exists('platform', $this->data) ? $this->data['platform'] : "U";
 | 
						|
        $migrated = strlen($company->company_key) == 32 ? "M" : ""; 
 | 
						|
        $trial = $account->isTrial() ? "T" : "";
 | 
						|
 | 
						|
        if(Ninja::isHosted())
 | 
						|
            $subject = "{$priority}Hosted-{$db}-{$is_large}{$platform}{$migrated}{$trial} :: {$plan} :: ".date('M jS, g:ia');
 | 
						|
        else
 | 
						|
            $subject = "{$priority}Self Hosted :: {$plan} :: {$is_large}{$platform}{$migrated} :: ".date('M jS, g:ia');
 | 
						|
 | 
						|
        return $this->from(config('mail.from.address'), $user->present()->name()) 
 | 
						|
                ->replyTo($user->email, $user->present()->name())
 | 
						|
                ->subject($subject)
 | 
						|
                ->view('email.support.message', [
 | 
						|
                    'support_message' => $this->data['message'],
 | 
						|
                    'system_info' => $system_info,
 | 
						|
                    'laravel_log' => $log_lines,
 | 
						|
                    'logo' => $company->present()->logo(),
 | 
						|
                    'settings' => $company->settings
 | 
						|
                ]);
 | 
						|
    }
 | 
						|
}
 |