Sto creando un'API di resto utilizzando Spring Boot e sto utilizzando la convalida dell'ibernazione per convalidare gli input delle richieste.
Ma ho bisogno anche di altri tipi di convalida, ad esempio quando è necessario verificare i dati di aggiornamento, se l'ID azienda non esiste Voglio lanciare un'eccezione personalizzata.
Questa convalida dovrebbe essere localizzata sul livello di servizio o sul livello del controllore?
Service Layer:
public Company update(Company entity) {
if (entity.getId() == null || repository.findOne(entity.getId()) == null) {
throw new ResourceNotFoundException("can not update un existence data with id : "
+ entity.getId());
}
return repository.saveAndFlush(entity);
}
Livello controller:
public HttpEntity<CompanyResource> update(@Valid @RequestBody Company companyRequest) {
Company company = companyService.getById(companyRequest.getId());
Precondition.checkDataFound(company,
"Can't not find data with id : " + companyRequest.getId());
// TODO : extract ignore properties to constant
BeanUtils.copyProperties(companyRequest, company, "createdBy", "createdDate",
"updatedBy", "updatedDate", "version", "markForDelete");
Company updatedCompany = companyService.update(company);
CompanyResource companyResource = companyAssembler.toResource(updatedCompany);
return new ResponseEntity<CompanyResource>(companyResource, HttpStatus.OK);
}