In order to enable auditing we need to add to Spring configuration. XML or JAVA Config, either way
Spring XML Configuraton
<mongo:auditing />
<mongo:mongo id="mongo" />
<bean class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg name="mongo" ref="mongo" />
<constructor-arg name="databaseName" value="blog-tests" />
</bean>
Spring Java Configuration
@Configuration
@EnableWebMvc
@ComponentScan(basePackages = "com.abc")
@EnableMongoRepositories(basePackages = "com.abc.xyz.repository")
@EnableMongoAuditing
public class MongoApplicationConfiguration {
@Bean
public MongoDbFactory mongoDbFactory() throws Exception {
ServerAddress serverAddress = new ServerAddress("127.0.0.1", 27017);
MongoCredential mongoCredential = MongoCredential.createCredential("user", "test", "samp".toCharArray());
MongoClient mongoClient = new MongoClient(serverAddress, Arrays.asList(mongoCredential));
return new SimpleMongoDbFactory(mongoClient, "test");
}
@Bean
public MongoTemplate mongoTemplate() throws Exception {
return new MongoTemplate(mongoDbFactory());
}
}
In order to use @CreatedBy and @LastModifiedBy you need to tell Spring who is a current user.
First add user related fields to your audited class:
@CreatedBy
private String createdBy;
@LastModifiedBy
private String lastModifiedBy;
Then create your implementation of AuditorAware that will obtain current user (probably from session or Spring Security context – depends on your application):
public class UserAudtiting implements AuditorAware<String> {
@Override
public String getCurrentAuditor() {
// get your user name here
String uname = SecurityContextHolder.getContext().getAuthentication().getName();
return Optional.of(uname);
}
}
Last thing is to tell Spring Data MongoDB about this auditor aware class by little modification in Mongo configuration:
<mongo:auditing auditor-aware-ref="auditor" />
<bean id="auditor" class="app.demo.UserAudtiting "/>
More details here: https://www.javacodegeeks.com/2013/05/auditing-entities-in-spring-data-mongodb.html