Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Dynamische Mailkonfiguration mit Werten aus Datenbank [Laravel]

Ich habe 3 Tage lang mit diesem Problem gekämpft, endlich habe ich einen Weg gefunden, es zu lösen.

Zuerst habe ich eine Tabelle mails erstellt und füllte es mit meinen Werten. Dann erstellte ich einen Anbieter 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);
            }
        }
    }
}

Und dann in der config\app.php registriert

App\Providers\MailConfigServiceProvider::class,