4

I have mail send function in laravel

public static function Compose($to,$cc,$bcc,$subject,$body)
    {

        // return $to;
        try
        {
            $data = [
                'body' => $body
            ];

            if(env('APP_ENV') == "local") 
            {
                $email["subject"] = $subject;
                $email["to"] = $to;
                $email["cc"] = $cc;
                $email["bcc"] = $bcc;
                Mail::send('email.composeMail', $data, function ($message) use ($email) {

                    $message
                        ->subject($email["subject"])
                        ->to($email["to"]);
                        ->cc($email["cc"]);
                        ->bcc($email["bcc"]);
                });
            }
            else
            {
                $email["subject"] = $subject;
                $email["to"] = $to;
                $email["cc"] = $cc;
                $email["bcc"] = $bcc;

                Mail::send('email.composeMail', $data, function ($message) use ($email) {

                    $message
                        ->subject($email["subject"])
                        ->to($email["to"]);
                        ->cc($email["cc"]);
                        ->bcc($email["bcc"]);
                });
            }
        } 
        catch (\Exception $e) 
        {
            Log::critical('Critical error occurred upon processing the transaction in Email.php -> Email class -> RevertPropertyToInbox method');
            throw new CustomErrorHandler($e->getMessage(),Constant::LogLevelCritical);
        }
    }

In many cases CC and BCC is Null. But mails aren't sent and I am getting error message

enter image description here

Here , I want to use code as it is without checking if CC or BCC is null, Is there any thing missed by me so that I can achieve what I am planning to .

Vishal Shetty
  • 1,618
  • 1
  • 27
  • 40
  • 2
    Why don't you want to check? It's the easiest thing in the world and a lot faster than asking for a solution that probably doesn't even exist – Josef Hoppe Jul 03 '17 at 11:30
  • In this case , I think if laravel have checked whether cc or bcc is blank then it would have ignored that directly without notifying developer , so I thought there might be something done by laravel where it checks that cc or bcc is blank and I am missing that – Vishal Shetty Jul 03 '17 at 11:56

2 Answers2

10

Those methods can all be called with an array instead of a plain string (docs). In that case, you should be able to just leave the array empty. Try this:

$message
    ->subject($email["subject"])
    ->to($email["to"]);
    ->cc($email["cc"] ?: []);
    ->bcc($email["bcc"] ?: []);
aross
  • 3,325
  • 3
  • 34
  • 42
  • problem is that if we leave array empty then error message is thrown, even for your code it is throwing same error message – Vishal Shetty Jul 03 '17 at 11:50
  • I guess then you found a bug in SwiftMailer. You could try to report that setting cc/bcc to an empty array is impossible (which is undocumented). – aross Jul 03 '17 at 12:30
2

you cannot send email if the email address is blank, it will always throw error

instead you need to check and then send email accordingly

try this

if($email["cc"] =='' && $email["bcc"] == ''){
 $message
                        ->subject($email["subject"])
                        ->to($email["to"]);
}
elseif($email["cc"] ==''){
$message
                        ->subject($email["subject"])
                        ->to($email["to"])
                        ->bcc($email["bcc"]);
}
else{

$message
                        ->subject($email["subject"])
                        ->to($email["to"])
                        ->cc($email["cc"]);

}
Exprator
  • 26,992
  • 6
  • 47
  • 59