* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Notifier\Transport; use Symfony\Component\Notifier\Exception\InvalidArgumentException; use Symfony\Component\Notifier\Exception\MissingRequiredOptionException; /** * @author Fabien Potencier * @author Oskar Stark */ final class Dsn { private string $scheme; private string $host; private ?string $user; private ?string $password; private ?int $port; private ?string $path; private array $options = []; private string $originalDsn; public function __construct(#[\SensitiveParameter] string $dsn) { $this->originalDsn = $dsn; if (false === $params = parse_url($dsn)) { throw new InvalidArgumentException('The notifier DSN is invalid.'); } if (!isset($params['scheme'])) { throw new InvalidArgumentException('The notifier DSN must contain a scheme.'); } $this->scheme = $params['scheme']; if (!isset($params['host'])) { throw new InvalidArgumentException('The notifier DSN must contain a host (use "default" by default).'); } $this->host = $params['host']; $this->user = '' !== ($params['user'] ?? '') ? rawurldecode($params['user']) : null; $this->password = '' !== ($params['pass'] ?? '') ? rawurldecode($params['pass']) : null; $this->port = $params['port'] ?? null; $this->path = $params['path'] ?? null; parse_str($params['query'] ?? '', $this->options); } public function getScheme(): string { return $this->scheme; } public function getHost(): string { return $this->host; } public function getUser(): ?string { return $this->user; } public function getPassword(): ?string { return $this->password; } public function getPort(?int $default = null): ?int { return $this->port ?? $default; } public function getOption(string $key, mixed $default = null): mixed { return $this->options[$key] ?? $default; } public function getRequiredOption(string $key): mixed { if (!\array_key_exists($key, $this->options) || '' === trim($this->options[$key])) { throw new MissingRequiredOptionException($key); } return $this->options[$key]; } public function getOptions(): array { return $this->options; } public function getPath(): ?string { return $this->path; } public function getOriginalDsn(): string { return $this->originalDsn; } }