import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
-import de.juplo.kafka.payment.transfer.domain.Transfer;
import de.juplo.kafka.payment.transfer.ports.CreateTransferUseCase;
import de.juplo.kafka.payment.transfer.ports.GetTransferUseCase;
import de.juplo.kafka.payment.transfer.ports.HandleStateChangeUseCase;
import java.time.Duration;
import java.util.List;
import java.util.Map;
+import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;
-import java.util.concurrent.ExecutorService;
import java.util.concurrent.Future;
import java.util.stream.Collectors;
-import static de.juplo.kafka.payment.transfer.domain.Transfer.State.CREATED;
-
@RequestMapping("/consumer")
@ResponseBody
{
private final String topic;
private final KafkaConsumer<String, String> consumer;
- private final ExecutorService executorService;
private final ObjectMapper mapper;
private final ConsumerUseCases productionUseCases, restoreUseCases;
NewTransferEvent newTransferEvent =
mapper.readValue(record.value(), NewTransferEvent.class);
- useCases.create(newTransferEvent.toTransfer().setState(CREATED));
+ useCases
+ .create(
+ newTransferEvent.getId(),
+ newTransferEvent.getPayer(),
+ newTransferEvent.getPayee(),
+ newTransferEvent.getAmount());
break;
case EventType.TRANSFER_STATE_CHANGED:
TransferStateChangedEvent stateChangedEvent =
mapper.readValue(record.value(), TransferStateChangedEvent.class);
- useCases
- .get(stateChangedEvent.getId())
- .ifPresentOrElse(
- transfer -> useCases.handle(transfer.setState(stateChangedEvent.getState())),
- () -> log.error("unknown transfer: {}", stateChangedEvent.getId()));
+ useCases.handleStateChange(stateChangedEvent.getId(), stateChangedEvent.getState());
break;
}
}
record.partition(),
record.value());
}
+ catch (IllegalArgumentException e)
+ {
+ log.error(
+ "ignoring invalid message #{} on {}/{}: {}, message={}",
+ record.offset(),
+ record.topic(),
+ record.partition(),
+ e.getMessage(),
+ record.value());
+ }
}
@EventListener
// in the same thread, it would block the completion of the initialization.
// Hence, the app would not react to any signal (CTRL-C, for example) except
// a KILL until the restoring is finished.
- future = executorService.submit(() -> restore());
+ future = CompletableFuture.runAsync(() -> restore());
}
private void restore()
}
running = true;
- future = executorService.submit(this);
+ future = CompletableFuture.runAsync(this);
log.info("started");
return result;