Подключение к динамической базе данных Symfony 4 и пользователь FOS

Используя Symfony 4, мы создаем многопользовательское приложение, где у каждого клиента есть выделенная база данных. Базы данных клиентов создаются автоматически по запросу при создании нового клиента. Во время этого процесса мы создаем уникальный дополнительный файл .env (специфичный для клиента), который содержит учетные данные для подключения к базе данных.

У нас есть 2 соединения с базой данных и 2 менеджера объектов - common и customer. Фактически, по умолчанию используется менеджер сущностей customer. Очевидно, что у менеджера сущностей customer сначала нет правильных параметров подключения. Мы загружаем дополнительный файл .env соответственно (например, на основе домена) по запросу ядра и соответственно устанавливаем соединение customer и диспетчер сущностей:

$connection = $this->entityManager->getConnection();
$connection->close();

$reflectionConn   = new \ReflectionObject($connection);
$reflectionParams = $reflectionConn->getProperty('params');
$reflectionParams->setAccessible(true);

$params             = $reflectionParams->getValue($connection);
$params['dbname']   = $database; // read from the customer specific .env
$params['user']     = $username; // read from the customer specific .env
$params['password'] = $password; // read from the customer specific .env

$reflectionParams->setValue($connection, $params);
$reflectionParams->setAccessible(false);

$this->entityManager = $this->entityManager->create(
    $this->entityManager->getConnection(),
    $this->entityManager->getConfiguration()
);

Это прекрасно работает!

Проблема в контексте безопасности (?) - мы используем FosUserBundle, который не может авторизовать пользователей. Я предполагаю, что приведенного выше кода недостаточно, чтобы повлиять на контекст безопасности.

Каким будет правильный способ достичь цели динамического подключения к базе данных + авторизации пользователя с использованием стандартного FosUserBundle?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
149
1

Ответы 1

Проблема вообще не была связана с контекстом безопасности. Проблема (глупая) заключалась в том, что мой прослушиватель запросов ядра имел приоритет по умолчанию (0), что приводило к загрузке всей конфигурации клиента и настройке соединения после того, как произошел прослушиватель входа в систему.

Установив его на 512 (должно быть достаточно), чтобы начать работу до SessionListener

Другие вопросы по теме