mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-10-01 01:36:00 -04:00
456afdcd4c
Added a notice to the top of each to explain they should not be normally modified. Standardised comment format used for each item. Better aligned some files with laravel 5.5 options.
112 lines
3.8 KiB
PHP
112 lines
3.8 KiB
PHP
<?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)) {
|
|
$redisServerKeys = ['host', 'port', 'database'];
|
|
$redisServers = explode(',', trim(env('REDIS_SERVERS', '127.0.0.1:6379:0'), ','));
|
|
$redisConfig = [
|
|
'cluster' => env('REDIS_CLUSTER', false)
|
|
];
|
|
foreach ($redisServers as $index => $redisServer) {
|
|
$redisServerName = ($index === 0) ? 'default' : 'redis-server-' . $index;
|
|
$redisServerDetails = explode(':', $redisServer);
|
|
if (count($redisServerDetails) < 2) $redisServerDetails[] = '6379';
|
|
if (count($redisServerDetails) < 3) $redisServerDetails[] = '0';
|
|
$redisConfig[$redisServerName] = array_combine($redisServerKeys, $redisServerDetails);
|
|
}
|
|
}
|
|
|
|
// 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' => [
|
|
|
|
'sqlite' => [
|
|
'driver' => 'sqlite',
|
|
'database' => storage_path('database.sqlite'),
|
|
'prefix' => '',
|
|
],
|
|
|
|
'mysql' => [
|
|
'driver' => 'mysql',
|
|
'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',
|
|
'prefix' => '',
|
|
'strict' => false,
|
|
'engine' => null,
|
|
],
|
|
|
|
'mysql_testing' => [
|
|
'driver' => 'mysql',
|
|
'host' => '127.0.0.1',
|
|
'database' => 'bookstack-test',
|
|
'username' => env('MYSQL_USER', 'bookstack-test'),
|
|
'password' => env('MYSQL_PASSWORD', 'bookstack-test'),
|
|
'charset' => 'utf8',
|
|
'collation' => 'utf8_unicode_ci',
|
|
'prefix' => '',
|
|
'strict' => false,
|
|
],
|
|
|
|
'pgsql' => [
|
|
'driver' => 'pgsql',
|
|
'host' => env('DB_HOST', 'localhost'),
|
|
'database' => env('DB_DATABASE', 'forge'),
|
|
'username' => env('DB_USERNAME', 'forge'),
|
|
'password' => env('DB_PASSWORD', ''),
|
|
'charset' => 'utf8',
|
|
'prefix' => '',
|
|
'schema' => 'public',
|
|
],
|
|
|
|
'sqlsrv' => [
|
|
'driver' => 'sqlsrv',
|
|
'host' => env('DB_HOST', 'localhost'),
|
|
'database' => env('DB_DATABASE', 'forge'),
|
|
'username' => env('DB_USERNAME', 'forge'),
|
|
'password' => env('DB_PASSWORD', ''),
|
|
'charset' => 'utf8',
|
|
'prefix' => '',
|
|
],
|
|
|
|
],
|
|
|
|
// 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' => env('REDIS_SERVERS', false) ? $redisConfig : [],
|
|
|
|
];
|