phinx.php 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?php
  2. declare(strict_types=1);
  3. $appEnv = getenv('APP_ENV') ?: 'production';
  4. if ($appEnv === 'development' && file_exists(__DIR__ . '/../.env')) {
  5. require_once __DIR__ . '/../vendor/autoload.php';
  6. $dotenv = Dotenv\Dotenv::createImmutable(__DIR__ . '/..');
  7. $dotenv->safeLoad();
  8. }
  9. $driver = getenv('DB_DRIVER') ?: 'sqlite';
  10. $envConfig = $driver === 'mysql'
  11. ? [
  12. 'adapter' => 'mysql',
  13. 'host' => getenv('DB_MYSQL_HOST') ?: 'mysql',
  14. 'port' => (int) (getenv('DB_MYSQL_PORT') ?: 3306),
  15. 'name' => getenv('DB_MYSQL_DATABASE') ?: '',
  16. 'user' => getenv('DB_MYSQL_USERNAME') ?: '',
  17. 'pass' => getenv('DB_MYSQL_PASSWORD') ?: '',
  18. 'charset' => 'utf8mb4',
  19. 'collation' => 'utf8mb4_unicode_ci',
  20. ]
  21. : [
  22. 'adapter' => 'sqlite',
  23. 'name' => rtrim((string) (getenv('DB_SQLITE_PATH') ?: '/data/irdb.sqlite'), '.sqlite'),
  24. 'suffix' => '.sqlite',
  25. ];
  26. return [
  27. 'paths' => [
  28. 'migrations' => __DIR__ . '/../db/migrations',
  29. 'seeds' => __DIR__ . '/../db/seeds',
  30. ],
  31. 'environments' => [
  32. 'default_migration_table' => 'phinxlog',
  33. 'default_environment' => 'app',
  34. 'app' => $envConfig,
  35. ],
  36. 'version_order' => 'creation',
  37. ];