Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Configuração de correio dinâmico com valores do banco de dados [Laravel]


Lutei por 3 dias com esse problema, finalmente descobri uma maneira de resolvê-lo.

Primeiro criei uma tabela mails e o preenchi com meus valores. Então criei um provedor MailConfigServiceProvider.php
<?php

namespace App\Providers;

use Config;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\ServiceProvider;

class MailConfigServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap the application services.
     *
     * @return void
     */
    public function boot()
    {
        //
    }

    /**
     * Register the application services.
     *
     * @return void
     */
    public function register()
    {
        if (\Schema::hasTable('mails')) {
            $mail = DB::table('mails')->first();
            if ($mail) //checking if table is not empty
            {
                $config = array(
                    'driver'     => $mail->driver,
                    'host'       => $mail->host,
                    'port'       => $mail->port,
                    'from'       => array('address' => $mail->from_address, 'name' => $mail->from_name),
                    'encryption' => $mail->encryption,
                    'username'   => $mail->username,
                    'password'   => $mail->password,
                    'sendmail'   => '/usr/sbin/sendmail -bs',
                    'pretend'    => false,
                );
                Config::set('mail', $config);
            }
        }
    }
}

E, em seguida, registrá-lo no config\app.php
App\Providers\MailConfigServiceProvider::class,