From 2e7669554ba48e68fbbcdf1e582b96287117103b Mon Sep 17 00:00:00 2001 From: Tigrov Date: Sat, 12 Oct 2024 12:03:13 +0700 Subject: [PATCH 1/3] Refactor `AbstractDsn` class --- src/Connection/AbstractDsn.php | 36 ++++++++++++++++++---------------- 1 file changed, 19 insertions(+), 17 deletions(-) diff --git a/src/Connection/AbstractDsn.php b/src/Connection/AbstractDsn.php index f8895c097..61cdc4374 100644 --- a/src/Connection/AbstractDsn.php +++ b/src/Connection/AbstractDsn.php @@ -17,37 +17,37 @@ abstract class AbstractDsn implements DsnInterface, Stringable { /** - * @psalm-param string[] $options + * @param string $driver The database driver name. + * @param string $host The database host name or IP address. + * @param string|null $databaseName The database name to connect to. + * @param string|null $port The database port. Null if isn't set. + * @param string[] $options The database connection options. Default value to an empty array. + * + * @psalm-param array $options */ public function __construct( - private string $driver, - private string $host, - private string|null $databaseName = null, - private string|null $port = null, - private array $options = [] + private readonly string $driver, + private readonly string $host, + private readonly string|null $databaseName = null, + private readonly string|null $port = null, + private readonly array $options = [] ) { } public function asString(): string { - $dsn = "$this->driver:" . "host=$this->host"; + $dsn = "$this->driver:host=$this->host"; if ($this->databaseName !== null && $this->databaseName !== '') { - $dsn .= ';' . "dbname=$this->databaseName"; + $dsn .= ";dbname=$this->databaseName"; } if ($this->port !== null) { - $dsn .= ';' . "port=$this->port"; + $dsn .= ";port=$this->port"; } - $parts = []; - foreach ($this->options as $key => $value) { - $parts[] = "$key=$value"; - } - - if (!empty($parts)) { - $dsn .= ';' . implode(';', $parts); + $dsn .= ";$key=$value"; } return $dsn; @@ -86,7 +86,9 @@ public function getHost(): string } /** - * @return array The database connection options. Default value to an empty array. + * @return string[] The database connection options. Default value to an empty array. + * + * @psalm-return array */ public function getOptions(): array { From 81a0172fce4aa7955ee2c5da85cde158e3c57ba8 Mon Sep 17 00:00:00 2001 From: StyleCI Bot Date: Sat, 12 Oct 2024 05:03:27 +0000 Subject: [PATCH 2/3] Apply fixes from StyleCI --- src/Connection/AbstractDsn.php | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/Connection/AbstractDsn.php b/src/Connection/AbstractDsn.php index 61cdc4374..8689a04f2 100644 --- a/src/Connection/AbstractDsn.php +++ b/src/Connection/AbstractDsn.php @@ -6,8 +6,6 @@ use Stringable; -use function implode; - /** * It's typically used to parse a DSN string, which is a string that has all the necessary information to connect * to a database, such as the database driver, hostname, database name, port, and options. From ca004388a9ee005a0d12c2d2c1e9fb05993473dd Mon Sep 17 00:00:00 2001 From: Tigrov Date: Sat, 12 Oct 2024 12:16:41 +0700 Subject: [PATCH 3/3] Add line to CHANGELOG.md [skip ci] --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index dcbc294f5..c7e82cd77 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -41,6 +41,7 @@ - Enh #878: Realize `ColumnBuilder` class (@Tigrov) - Enh #881: Refactor `ColumnSchemaInterface` and `AbstractColumnSchema` (@Tigrov) - End #882: Move `ArrayColumnSchema` and `StructuredColumnSchema` classes from `db-pgsql` package (@Tigrov) +- Enh #885: Refactor `AbstractDsn` class (@Tigrov) ## 1.3.0 March 21, 2024