From 358f8b24fb5cccffbae14b82427a16e54af07d33 Mon Sep 17 00:00:00 2001 From: Yossi Rizgan Date: Thu, 22 Feb 2018 13:54:42 +0200 Subject: [PATCH] add 'Last-Event-Id' header 'Last-Event-Id' is part of SSE protool, used for handling retry correctly by restring last event sent to client --- .../java/com/here/oksse/RealServerSentEvent.java | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/here/oksse/RealServerSentEvent.java b/src/main/java/com/here/oksse/RealServerSentEvent.java index f9556a8..6cade82 100644 --- a/src/main/java/com/here/oksse/RealServerSentEvent.java +++ b/src/main/java/com/here/oksse/RealServerSentEvent.java @@ -34,6 +34,7 @@ class RealServerSentEvent implements ServerSentEvent { private long reconnectTime = TimeUnit.SECONDS.toMillis(3); private long readTimeoutMillis = 0; + private String lastEventId; RealServerSentEvent(Request request, Listener listener) { if (!"GET".equals(request.method())) { @@ -53,13 +54,16 @@ private void prepareCall(Request request) { if (client == null) { throw new AssertionError("Client is null"); } - Request newRequest = request.newBuilder() + Request.Builder requestBuilder = request.newBuilder() .header("Accept-Encoding", "") .header("Accept", "text/event-stream") - .header("Cache-Control", "no-cache") - .build(); + .header("Cache-Control", "no-cache"); - call = client.newCall(newRequest); + if (lastEventId != null) { + requestBuilder.header("Last-Event-Id", lastEventId); + } + + call = client.newCall(requestBuilder.build()); } private void enqueue() { @@ -168,7 +172,6 @@ private class Reader { // Intentionally done to reuse StringBuilder for memory optimization @SuppressWarnings("PMD.AvoidStringBufferField") private StringBuilder data = new StringBuilder(); - private String lastEventId; private String eventName = DEFAULT_EVENT; Reader(BufferedSource source) { @@ -216,7 +219,7 @@ void setTimeout(long timeout, TimeUnit unit) { private void processLine(String line) { //log("Sse read line: " + line); - if (line.isEmpty()) { // If the line is empty (a blank line). Dispatch the event. + if (line == null || line.isEmpty()) { // If the line is empty (a blank line). Dispatch the event. dispatchEvent(); return; }