Laravel - сделать логику в config / database.php - PullRequest
0 голосов
/ 17 апреля 2019

Как вы все знаете, в Laravel config/database.php есть куча arrays и values. Но для определенных условий мне нужно выполнить некоторую логику там, и мне удается сделать некоторую простую логику в config/database.php, и она работает так, как я хочу (может ссылаться на код ниже), но мне интересно, хорошо ли это / практично делать так?

Если это не практично, можете ли вы предложить другой способ получить тот же результат, что и ниже?

'connections' => [

    'mysql' => (function(){ 
        $config = [
            'driver' => 'mysql',
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'live_db'),
            'username' => env('DB_USERNAME', 'myuser'),
            'password' => env('DB_PASSWORD', '2309423234'),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8',
            'collation' => 'utf8_unicode_ci',
            'prefix' => 'gn_',
            //'prefix_indexes' => true,
            'strict' => false,
            'engine' => env('DB_ENGINE', null),
        ]; 

        // do some logic here (and it's working!!)
        // but........
        // is it okay to do like this?
        if(env('DB_WITH_SSLMODE', false)){
            $config += [
                'sslmode' => env('DB_SSLMODE', 'prefer'),
                'options'   => [
                    PDO::MYSQL_ATTR_SSL_CA    => env('DB_OPT_MYSQL_ATTR_SSL_CA', 'C:\wamp64\bin\cloudsql\certificates\server-ca.pem'),
                    PDO::MYSQL_ATTR_SSL_CERT    => env('DB_OPT_MYSQL_ATTR_SSL_CERT', 'C:\wamp64\bin\cloudsql\certificates\client-cert.pem'),
                    PDO::MYSQL_ATTR_SSL_KEY    => env('DB_OPT_MYSQL_ATTR_SSL_KEY', 'C:\wamp64\bin\cloudsql\certificates\client-key.pem'),
                    PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => env('DB_OPT_MYSQL_ATTR_SSL_VERIFY_SERVER_CERT', false)
                ],
            ];
        }

        return $config;
    })(),

],

Ответы [ 2 ]

2 голосов
/ 17 апреля 2019

Для этого вы можете создать поставщика услуг:

class SSLServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap any application services.
     *
     * @return void
     */
    public function boot(Kernel $kernel)
    {

    }

    /**
     * Register any application services.
     *
     * @return void
     */
    public function register()
    {
        $config = \Config::get('database.connections.mysql');

        if (env('DB_WITH_SSLMODE', false)) {
            $config += [
                'sslmode' => env('DB_SSLMODE', 'prefer'),
                'options' => [
                    \PDO::MYSQL_ATTR_SSL_CA => env('DB_OPT_MYSQL_ATTR_SSL_CA',
                        'C:\wamp64\bin\cloudsql\certificates\server-ca.pem'),
                    \PDO::MYSQL_ATTR_SSL_CERT => env('DB_OPT_MYSQL_ATTR_SSL_CERT',
                        'C:\wamp64\bin\cloudsql\certificates\client-cert.pem'),
                    \PDO::MYSQL_ATTR_SSL_KEY => env('DB_OPT_MYSQL_ATTR_SSL_KEY',
                        'C:\wamp64\bin\cloudsql\certificates\client-key.pem'),
                    \PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => env('DB_OPT_MYSQL_ATTR_SSL_VERIFY_SERVER_CERT', false)
                ],
            ];
        }

        \Config::set('database.connections.mysql', $config);

    }

}

и не забудьте зарегистрировать своего поставщика услуг в config / app.php

App\Providers\SSLServiceProvider::class,
1 голос
/ 17 апреля 2019

А как насчет использования троичного оператора?(почти как по умолчанию в laravel 5.8).

Примечание: первое решение не удаляет sslmode из массива config.Если вам нужно сделать это, просто перейдите ко второму варианту!

1) Он должен работать так:

'connections' => [
    'mysql' => [
        'driver' => 'mysql',
        'host' => env('DB_HOST', '127.0.0.1'),
        'port' => env('DB_PORT', '3306'),
        'database' => env('DB_DATABASE', 'forge'),
        'username' => env('DB_USERNAME', 'forge'),
        'password' => env('DB_PASSWORD', ''),
        'unix_socket' => env('DB_SOCKET', ''),
        'charset' => 'utf8mb4',
        'collation' => 'utf8mb4_unicode_ci',
        'prefix' => '',
        'prefix_indexes' => true,
        'strict' => true,
        'engine' => null,
        'sslmode' => env('DB_WITH_SSLMODE') ? env('DB_SSLMODE','prefer') : null,
        'options' => (extension_loaded('pdo_mysql') && env('DB_WITH_SSLMODE')) ? [
            PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
            PDO::MYSQL_ATTR_SSL_CERT => env('MYSQL_ATTR_SSL_CERT'),
            PDO::MYSQL_ATTR_SSL_KEY => env('MYSQL_ATTR_SSL_KEY'),
            PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => env('MYSQL_ATTR_SSL_VERIFY_SERVER_CERT')
        ] : [],
    ],
],

или

2) грязное решение но с одним условным условием:

'connections' => [
    'mysql' => array_merge([
        'driver' => 'mysql',
        'host' => env('DB_HOST', '127.0.0.1'),
        'port' => env('DB_PORT', '3306'),
        'database' => env('DB_DATABASE', 'forge'),
        'username' => env('DB_USERNAME', 'forge'),
        'password' => env('DB_PASSWORD', ''),
        'unix_socket' => env('DB_SOCKET', ''),
        'charset' => 'utf8mb4',
        'collation' => 'utf8mb4_unicode_ci',
        'prefix' => '',
        'prefix_indexes' => true,
        'strict' => true,
        'engine' => null
    ], (extension_loaded('pdo_mysql') && env('DB_WITH_SSLMODE')) ? [
        'sslmode' => env('DB_SSLMODE', 'prefer'),
        'options' => [
            PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
            PDO::MYSQL_ATTR_SSL_CERT => env('MYSQL_ATTR_SSL_CERT'),
            PDO::MYSQL_ATTR_SSL_KEY => env('MYSQL_ATTR_SSL_KEY'),
            PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => env('MYSQL_ATTR_SSL_VERIFY_SERVER_CERT')
        ]
    ] : [ 'options' => [] ]),
],

Затем переместите значения по умолчанию, которые у вас были в env (), в ваш файл .env (обратите внимание, что я удалил DB_OPT_ префикс):

DB_WITH_SSLMODE=true
MYSQL_ATTR_SSL_CA=C:\wamp64\bin\cloudsql\certificates\server-ca.pem
MYSQL_ATTR_SSL_CERT=C:\wamp64\bin\cloudsql\certificates\client-cert.pem
MYSQL_ATTR_SSL_KEY=C:\wamp64\bin\cloudsql\certificates\client-key.pem
MYSQL_ATTR_SSL_VERIFY_SERVER_CERT=false

Таким образом, если вы установите для DB_WITH_SSLMODE значение false, будет возвращен пустой массив и ssl не будет включен.

Примечание: Я думаю, что sslmode , который вы указали, нужен только для соединений с PostgreSQL, а это не ваш случай.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...