EclipseLink Audit / History / Track changes
Eu tentei implementar uma maneira de rastrear alterações de dados e criar um log de histórico para o meu aplicativo. Porque eu estou usando o EclipseLink, deve ser fácil e possível obter as mudanças como elasescreva no FAQ do EclipseLink A primeira solução funciona, mas o segundo evento baseado não funciona. Toda vez que o evento é gerado, o ObjectChangeSet é nulo.
A razão pela qual eu não estou simplesmente usando HistoryPolicy é que eu não posso armazenar informações sobre o usuário conectado (não o usuário db) e os dados alterados para uma tabela separada. Eu procurei muito, mas não consigo encontrar nenhuma solução para esse problema.
Esta é minha classe de entidade:
@Entity
@EntityListeners(HistoryEventListener.class)
@Table(name = "t_users")
public class Users implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "GENSEQ_USERS")
@SequenceGenerator(name = "GENSEQ_USERS", sequenceName = "SEQ_USERS", allocationSize = 1, initialValue = 1)
private Integer id;
@Column(nullable = false)
private String userid;
...
}
E esta é minha classe DescriptorEventAdapter:
public class HistoryEventListener extends DescriptorEventAdapter {
@Override
public void postUpdate(DescriptorEvent event) {
ObjectChangeSet changeSet = event.getChangeSet();
if (changeSet != null) {
System.out.println("ObjectChangeSet not null");
}
System.out.println("ObjectChangeSet null");
}
@Override
public void postMerge(DescriptorEvent event) {
ObjectChangeSet changeSet = event.getChangeSet();
if (changeSet != null) {
System.out.println("ObjectChangeSet not null");
}
System.out.println("ObjectChangeSet null");
}
}
O arquivo persistence.xml que eu usei:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="PhoneBookPU" transaction-type="RESOURCE_LOCAL">
<provider>
org.eclipse.persistence.jpa.PersistenceProvider
</provider>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="javax.persistence.jdbc.driver" value="oracle.jdbc.OracleDriver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:oracle:thin:@somehostname:1521:xyz"/>
<property name="javax.persistence.jdbc.password" value="getyourown"/>
<property name="javax.persistence.jdbc.user" value="username"/>
<property name="javax.persistence.logging.level" value="INFO"/>
</properties>
</persistence-unit>
</persistence>
Qualquer ajuda seria muito apreciada.