From 889fa9ffb91cd44d3d4b77e82b39c9cb81fc7750 Mon Sep 17 00:00:00 2001 From: Steve Hawkins Date: Mon, 4 Dec 2023 11:05:32 -0500 Subject: [PATCH] fix: escapes $$ prior to escaping \$ closes: #1056 Signed-off-by: Steve Hawkins --- .../config/ExpressionConfigSourceInterceptor.java | 12 ++++++++---- .../ExpressionConfigSourceInterceptorTest.java | 4 ++-- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/implementation/src/main/java/io/smallrye/config/ExpressionConfigSourceInterceptor.java b/implementation/src/main/java/io/smallrye/config/ExpressionConfigSourceInterceptor.java index ec8890e99..4460e936e 100644 --- a/implementation/src/main/java/io/smallrye/config/ExpressionConfigSourceInterceptor.java +++ b/implementation/src/main/java/io/smallrye/config/ExpressionConfigSourceInterceptor.java @@ -98,14 +98,18 @@ public void accept(ResolveContext resolveContext, StringBuilde * dollar. */ private String escapeDollarIfExists(final String value) { - int index = value.indexOf("\\$"); + return escapeIfExists(escapeIfExists(value, "$$", "$$$$"), "\\$", "$$"); + } + + private String escapeIfExists(final String value, final String toEscape, final String escaped) { + int index = value.indexOf(toEscape); if (index != -1) { int start = 0; StringBuilder builder = new StringBuilder(); while (index != -1) { - builder.append(value, start, index).append("$$"); - start = index + 2; - index = value.indexOf("\\$", start); + builder.append(value, start, index).append(escaped); + start = index + toEscape.length(); + index = value.indexOf(toEscape, start); } builder.append(value.substring(start)); return builder.toString(); diff --git a/implementation/src/test/java/io/smallrye/config/ExpressionConfigSourceInterceptorTest.java b/implementation/src/test/java/io/smallrye/config/ExpressionConfigSourceInterceptorTest.java index 6ca5abf49..0c9dbf4a0 100644 --- a/implementation/src/test/java/io/smallrye/config/ExpressionConfigSourceInterceptorTest.java +++ b/implementation/src/test/java/io/smallrye/config/ExpressionConfigSourceInterceptorTest.java @@ -119,10 +119,10 @@ void withoutExpansion() { @Test void escape() { - assertEquals("${my.prop}", buildConfig("expression", "$${my.prop}").getRawValue("expression")); + assertEquals("$${my.prop}", buildConfig("expression", "$${my.prop}").getRawValue("expression")); assertEquals("${my.prop}", buildConfig("expression", "\\${my.prop}").getRawValue("expression")); - assertEquals("file:target/prices/?fileName=${date:now:yyyyMMddssSS}.txt&charset=utf-8", + assertEquals("file:target/prices/?fileName=$${date:now:yyyyMMddssSS}.txt&charset=utf-8", buildConfig("camel.expression", "file:target/prices/?fileName=$${date:now:yyyyMMddssSS}.txt&charset=utf-8") .getRawValue("camel.expression"));