<?php /** * Database configuration options. * * Changes to these config files are not supported by BookStack and may break upon updates. * Configuration should be altered via the `.env` file or environment variables. * Do not edit this file unless you're happy to maintain any changes yourself. */ // REDIS // Split out configuration into an array if (env('REDIS_SERVERS', false)) { $redisDefaults = ['host' => '127.0.0.1', 'port' => '6379', 'database' => '0', 'password' => null]; $redisServers = explode(',', trim(env('REDIS_SERVERS', '127.0.0.1:6379:0'), ',')); $redisConfig = ['client' => 'predis']; $cluster = count($redisServers) > 1; if ($cluster) { $redisConfig['clusters'] = ['default' => []]; } foreach ($redisServers as $index => $redisServer) { $redisServerDetails = explode(':', $redisServer); $serverConfig = []; $configIndex = 0; foreach ($redisDefaults as $configKey => $configDefault) { $serverConfig[$configKey] = ($redisServerDetails[$configIndex] ?? $configDefault); $configIndex++; } if ($cluster) { $redisConfig['clusters']['default'][] = $serverConfig; } else { $redisConfig['default'] = $serverConfig; } } } // MYSQL // Split out port from host if set $mysql_host = env('DB_HOST', 'localhost'); $mysql_host_exploded = explode(':', $mysql_host); $mysql_port = env('DB_PORT', 3306); if (count($mysql_host_exploded) > 1) { $mysql_host = $mysql_host_exploded[0]; $mysql_port = intval($mysql_host_exploded[1]); } return [ // Default database connection name. // Options: mysql, mysql_testing 'default' => env('DB_CONNECTION', 'mysql'), // Available database connections // Many of those shown here are unsupported by BookStack. 'connections' => [ 'mysql' => [ 'driver' => 'mysql', 'url' => env('DATABASE_URL'), 'host' => $mysql_host, 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'port' => $mysql_port, 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', // Prefixes are only semi-supported and may be unstable // since they are not tested as part of our automated test suite. // If used, the prefix should not be changed otherwise you will likely receive errors. 'prefix' => env('DB_TABLE_PREFIX', ''), 'prefix_indexes' => true, 'strict' => false, 'engine' => null, 'options' => extension_loaded('pdo_mysql') ? array_filter([ PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'), ]) : [], ], 'mysql_testing' => [ 'driver' => 'mysql', 'url' => env('TEST_DATABASE_URL'), 'host' => '127.0.0.1', 'database' => 'bookstack-test', 'username' => env('MYSQL_USER', 'bookstack-test'), 'password' => env('MYSQL_PASSWORD', 'bookstack-test'), 'port' => $mysql_port, 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'prefix_indexes' => true, 'strict' => false, ], ], // Migration Repository Table // This table keeps track of all the migrations that have already run for // your application. Using this information, we can determine which of // the migrations on disk haven't actually been run in the database. 'migrations' => 'migrations', // Redis configuration to use if set 'redis' => $redisConfig ?? [], ];