ca.gc.aafc.dina.DinaBaseApiAutoConfiguration Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dina-base-api Show documentation
Show all versions of dina-base-api Show documentation
Base DINA API package for Java built on SpringBoot and Crnk
package ca.gc.aafc.dina;
import io.crnk.core.engine.transaction.TransactionRunner;
import io.crnk.core.queryspec.mapper.DefaultQuerySpecUrlMapper;
import io.crnk.operations.server.OperationsModule;
import io.crnk.operations.server.TransactionOperationFilter;
import io.crnk.spring.jpa.SpringTransactionRunner;
import io.micrometer.core.aop.TimedAspect;
import io.micrometer.core.instrument.MeterRegistry;
import org.springframework.boot.autoconfigure.web.ServerProperties;
import org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController;
import org.springframework.boot.autoconfigure.web.servlet.error.ErrorViewResolver;
import org.springframework.boot.web.servlet.error.ErrorAttributes;
import org.springframework.context.MessageSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.DependsOn;
import org.springframework.context.support.ReloadableResourceBundleMessageSource;
import org.springframework.validation.beanvalidation.LocalValidatorFactoryBean;
import org.springframework.web.servlet.LocaleResolver;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.i18n.LocaleChangeInterceptor;
import org.springframework.web.servlet.i18n.SessionLocaleResolver;
import java.util.List;
import javax.inject.Inject;
import javax.inject.Named;
import java.util.Locale;
import ca.gc.aafc.dina.crkn.PatchedCrnkErrorController;
@Configuration
// Must explicitly depend on "querySpecUrlMapper" so Spring can inject it into this class'
// initQuerySpecUrlMapper method.
@DependsOn("querySpecUrlMapper")
public class DinaBaseApiAutoConfiguration implements WebMvcConfigurer {
@Inject
public void initQuerySpecUrlMapper(DefaultQuerySpecUrlMapper mapper) {
// Disables Crnk's behavior of splitting up query params that contain commas into HashSets.
// This will allow RSQL 'OR' filters like "name==primer2,name==primer4".
mapper.setAllowCommaSeparatedValue(false);
}
/**
* Registers the transaction filter that executes a transaction around bulk jsonpatch operations.
*
* @param module the Crnk operations module.
*/
@Inject
public void initTransactionOperationFilter(OperationsModule module) {
module.addFilter(new TransactionOperationFilter());
module.setIncludeChangedRelationships(false);
module.setResumeOnError(true);
}
/**
* override Crnk provided ErrorController so it can work with SpringBoot >= 2.5
*/
@Bean
public BasicErrorController jsonapiErrorController(ErrorAttributes errorAttributes, ServerProperties serverProperties, List errorViewResolvers) {
return new PatchedCrnkErrorController(errorAttributes, serverProperties.getError(), errorViewResolvers);
}
@Bean
public TimedAspect timedAspect(MeterRegistry registry) {
return new TimedAspect(registry);
}
/**
* Provides Crnk's SpringTransactionRunner that implements transactions around bulk jsonpatch
* operations using Spring's transaction management.
*
* @return the transaction runner.
*/
@Bean
public TransactionRunner crnkSpringTransactionRunner() {
return new SpringTransactionRunner();
}
@Bean
public LocaleResolver localeResolver() {
SessionLocaleResolver slr = new SessionLocaleResolver();
slr.setDefaultLocale(Locale.ENGLISH);
return slr;
}
@Bean
public LocaleChangeInterceptor localeChangeInterceptor() {
LocaleChangeInterceptor lci = new LocaleChangeInterceptor();
lci.setParamName("lang");
return lci;
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(localeChangeInterceptor());
}
@Bean
@Named("validationMessageSource")
public MessageSource baseValidationMessageSource() {
ReloadableResourceBundleMessageSource messageSource = new ReloadableResourceBundleMessageSource();
messageSource.setAlwaysUseMessageFormat(true);
messageSource.setBasename("classpath:base-validation-messages");
messageSource.setDefaultEncoding("UTF-8");
return messageSource;
}
@Bean
public MessageSource messageSource() {
ReloadableResourceBundleMessageSource messageSource = new ReloadableResourceBundleMessageSource();
messageSource.setAlwaysUseMessageFormat(true);
messageSource.setBasename("classpath:validation-messages");
messageSource.setDefaultEncoding("UTF-8");
return messageSource;
}
@Bean
@Override
public LocalValidatorFactoryBean getValidator() {
LocalValidatorFactoryBean bean = new LocalValidatorFactoryBean();
bean.setValidationMessageSource(messageSource());
return bean;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy