diff --git a/README.md b/README.md index b023e73..911da04 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# th2-conn-dirty-fix (1.4.2) +# th2-conn-dirty-fix (1.5.1) This microservice allows sending and receiving messages via FIX protocol @@ -335,6 +335,12 @@ spec: # Changelog +## 1.5.1 + +* Property `th2.operation_timestamp` is added to metadata to each message +* Use mutable map for metadata when sending a messages from the handler + * Fix error when new property with operation timestamp added to the immutable map + ## 1.5.0 * `minConnectionTimeoutOnSend` parameter is added. diff --git a/src/main/java/com/exactpro/th2/FixHandler.java b/src/main/java/com/exactpro/th2/FixHandler.java index 21261bb..cb3b06e 100644 --- a/src/main/java/com/exactpro/th2/FixHandler.java +++ b/src/main/java/com/exactpro/th2/FixHandler.java @@ -586,7 +586,7 @@ public void sendResendRequest(int beginSeqNo, int endSeqNo) { //do private resendRequest.append(BEGIN_SEQ_NO).append(beginSeqNo).append(SOH); resendRequest.append(END_SEQ_NO).append(endSeqNo).append(SOH); setChecksumAndBodyLength(resendRequest); - channel.send(Unpooled.wrappedBuffer(resendRequest.toString().getBytes(StandardCharsets.UTF_8)), Collections.emptyMap(), null, IChannel.SendMode.MANGLE); + channel.send(Unpooled.wrappedBuffer(resendRequest.toString().getBytes(StandardCharsets.UTF_8)), createMetadataMap(), null, IChannel.SendMode.MANGLE); resetHeartbeatTask(); } @@ -598,7 +598,7 @@ void sendResendRequest(int beginSeqNo) { //do private setChecksumAndBodyLength(resendRequest); if (enabled.get()) { - channel.send(Unpooled.wrappedBuffer(resendRequest.toString().getBytes(StandardCharsets.UTF_8)), Collections.emptyMap(), null, IChannel.SendMode.MANGLE); + channel.send(Unpooled.wrappedBuffer(resendRequest.toString().getBytes(StandardCharsets.UTF_8)), createMetadataMap(), null, IChannel.SendMode.MANGLE); resetHeartbeatTask(); } else { sendLogon(); @@ -655,7 +655,7 @@ private void recovery(int beginSeqNo, int endSeqNo) { if(sequence - 1 != lastProcessedSequence.get() ) { StringBuilder sequenceReset = createSequenceReset(Math.max(beginSeqNo, lastProcessedSequence.get() + 1), sequence); - channel.send(Unpooled.wrappedBuffer(sequenceReset.toString().getBytes(StandardCharsets.UTF_8)), Collections.emptyMap(), null, SendMode.MANGLE); + channel.send(Unpooled.wrappedBuffer(sequenceReset.toString().getBytes(StandardCharsets.UTF_8)), createMetadataMap(), null, SendMode.MANGLE); resetHeartbeatTask(); } @@ -663,7 +663,7 @@ private void recovery(int beginSeqNo, int endSeqNo) { setPossDup(buf); updateLength(buf); updateChecksum(buf); - channel.send(buf, Collections.emptyMap(), null, SendMode.MANGLE); + channel.send(buf, createMetadataMap(), null, SendMode.MANGLE); resetHeartbeatTask(); @@ -681,7 +681,7 @@ private void recovery(int beginSeqNo, int endSeqNo) { String seqReset = createSequenceReset(Math.max(lastProcessedSequence.get() + 1, beginSeqNo), msgSeqNum.get() + 1).toString(); channel.send( Unpooled.wrappedBuffer(seqReset.getBytes(StandardCharsets.UTF_8)), - Collections.emptyMap(), null, SendMode.MANGLE + createMetadataMap(), null, SendMode.MANGLE ); } } else { @@ -689,7 +689,7 @@ private void recovery(int beginSeqNo, int endSeqNo) { createSequenceReset(beginSeqNo, msgSeqNum.get() + 1).toString(); channel.send( Unpooled.wrappedBuffer(seqReset.getBytes(StandardCharsets.UTF_8)), - Collections.emptyMap(), null, SendMode.MANGLE + createMetadataMap(), null, SendMode.MANGLE ); } resetHeartbeatTask(); @@ -700,7 +700,7 @@ private void recovery(int beginSeqNo, int endSeqNo) { createSequenceReset(Math.max(beginSeqNo, lastProcessedSequence.get() + 1), msgSeqNum.get() + 1).toString(); channel.send( Unpooled.buffer().writeBytes(seqReset.getBytes(StandardCharsets.UTF_8)), - Collections.emptyMap(), null, SendMode.MANGLE + createMetadataMap(), null, SendMode.MANGLE ); } finally { recoveryLock.unlock(); @@ -716,7 +716,7 @@ private void sendSequenceReset() { setChecksumAndBodyLength(sequenceReset); if (enabled.get()) { - channel.send(Unpooled.wrappedBuffer(sequenceReset.toString().getBytes(StandardCharsets.UTF_8)), Collections.emptyMap(), null, IChannel.SendMode.MANGLE); + channel.send(Unpooled.wrappedBuffer(sequenceReset.toString().getBytes(StandardCharsets.UTF_8)), createMetadataMap(), null, IChannel.SendMode.MANGLE); resetHeartbeatTask(); } else { sendLogon(); @@ -880,7 +880,7 @@ private void sendHeartbeatTestReqId(String testReqId) { if (enabled.get()) { info("Send Heartbeat to server - %s", heartbeat); - channel.send(Unpooled.wrappedBuffer(heartbeat.toString().getBytes(StandardCharsets.UTF_8)), Collections.emptyMap(), null, IChannel.SendMode.MANGLE); + channel.send(Unpooled.wrappedBuffer(heartbeat.toString().getBytes(StandardCharsets.UTF_8)), createMetadataMap(), null, IChannel.SendMode.MANGLE); resetHeartbeatTask(); } else { @@ -894,7 +894,7 @@ public void sendTestRequest() { //do private testRequest.append(TEST_REQ_ID).append(testReqID.incrementAndGet()); setChecksumAndBodyLength(testRequest); if (enabled.get()) { - channel.send(Unpooled.wrappedBuffer(testRequest.toString().getBytes(StandardCharsets.UTF_8)), Collections.emptyMap(), null, IChannel.SendMode.MANGLE); + channel.send(Unpooled.wrappedBuffer(testRequest.toString().getBytes(StandardCharsets.UTF_8)), createMetadataMap(), null, IChannel.SendMode.MANGLE); info("Send TestRequest to server - %s", testRequest); resetTestRequestTask(); resetHeartbeatTask(); @@ -942,7 +942,7 @@ public void sendLogon() { setChecksumAndBodyLength(logon); info("Send logon - %s", logon); - channel.send(Unpooled.wrappedBuffer(logon.toString().getBytes(StandardCharsets.UTF_8)), Collections.emptyMap(), null, IChannel.SendMode.MANGLE); + channel.send(Unpooled.wrappedBuffer(logon.toString().getBytes(StandardCharsets.UTF_8)), createMetadataMap(), null, IChannel.SendMode.MANGLE); } private void sendLogout() { @@ -963,7 +963,7 @@ private void sendLogout(String text) { try { channel.send( Unpooled.wrappedBuffer(logout.toString().getBytes(StandardCharsets.UTF_8)), - Collections.emptyMap(), + createMetadataMap(), null, IChannel.SendMode.MANGLE ).get(); @@ -1174,4 +1174,8 @@ private void debug(String message, Object... args) { LOGGER.debug("{} - {}: {}", channel.getSessionGroup(), channel.getSessionAlias(), String.format(message, args)); } } + + private Map<String, String> createMetadataMap() { + return new HashMap<>(2); + } } \ No newline at end of file