I'm trying to send an email with php and swiftmailer, using STARTTLS, but I'm getting a certificate error. I have root access to the SMTP server, and the certificate used is self-signed. I'm using Debian on both machines (web server and smtp server)
PHP message: PHP Warning: stream_socket_enable_crypto(): SSL operation failed with code 1. OpenSSL Error messages:
error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed in [..]/lib/classes/Swift/Transport/StreamBuffer.php on line 97
PHP message: PHP Fatal error: Uncaught exception 'Swift_TransportException' with message 'Unable to connect with TLS encryption' in [..]/lib/classes/Swift/Transport/EsmtpTransport.php:294
Do I need to add my own certificate somewhere to get it accepted? Or is this some OpenSSL configuration error?
You do not need to edit
/vendor
files. You can specify (undocumented) options in yourconfig/mail.php
file:You can check it yourself in
vendor/laravel/framework/src/Illuminate/Mail/TransportManager.php
on line ~50:I got the same problem using Swiftmailer in Laravel.
Looks like there is no option for this in Swiftmailer. Clean solution would be to add your own root CA to your server and sign your mail server certificate with this CA. The certificate would be valid after this. See for example this tutorial.
Anyway, a quick dirty hack you should not use would be to edit
swiftmailer\swiftmailer\lib\classes\Swift\Transport\StreamBuffer.php
. In_establishSocketConnection()
line 253 replace:with something like this:
This will change the ssl options of stream_context_create() (a few lines below
$options
):Swiftmailer has now been updated to include an option for this. It can now be solved using the
setStreamOptions
method from yourSwift_SmtpTransport
instance rather than editing the swift class.