sql >> Databáze >  >> RDS >> Mysql

Dynamická konfigurace pošty s hodnotami z databáze [Laravel]

S tímto problémem jsem se potýkal 3 dny a nakonec jsem přišel na způsob, jak jej vyřešit.

Nejprve jsem vytvořil tabulku mails a naplnil jej svými hodnotami. Pak jsem vytvořil poskytovatele 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);
            }
        }
    }
}

A pak jej zaregistroval v config\app.php

App\Providers\MailConfigServiceProvider::class,


  1. Typ sloupce MySQL TIMESTAMP implicitně zahrnuje NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP

  2. CROSS JOIN vs INNER JOIN v SQL

  3. Zobrazte každou hodnotu pole DISTINCT pouze jednou pomocí smyčky

  4. ukládání peněžních částek v mysql