Я хотел бы сохранить имя пользователя с последней измененной строкой таблицы в качестве поля в каждой таблице.
У меня есть следующие настройки: пользователь входит в систему, веб-слой вызывает некоторые компоненты EJB 3.0. Эти EJB-бины создают и модифицируют некоторые сущности JPA.
Теперь я хотел бы, чтобы это имя пользователя (из веб-слоя) автоматически сохранялось для каждой сущности JPA (и строки базы данных), которая создается или изменяется во время вызова метода EJB.
У меня есть такая таблица (то есть: каждая таблица имеет модификатор поля):
CREATE TABLE my_table (
some_data INTEGER,
modifier VARCHAR(20)
);
Под автоматически я имею в виду, что мне не нужно было бы вручную устанавливать имя пользователя для каждой сущности в методах EJB.
Этого можно достичь, сохранив имя пользователя в переменной ThreadLocal и выбрав имя пользователя из ThreadLocal в EntityListener сущности JPA.
Однако это работает только при использовании локального вызова EJB, оно не будет работать с вызовами EJB, которые пересекают границы JVM. Я хотел бы сделать это через удаленные вызовы EJB-методов.
Это вообще возможно?
Я использую Weblogic Server 10.3, EJB3.0 и EclipseLink JPA. Мне также интересно услышать, работает ли это с другими реализациями JPA.