From b9b4eee0bc9083c4765d2ae779cbc15fdf382428 Mon Sep 17 00:00:00 2001 From: David Sloan <33483659+davidsloan@users.noreply.github.com> Date: Tue, 31 Oct 2023 20:10:34 +0000 Subject: [PATCH] Fix file encoding selection (#68) --- project/Settings.scala | 2 +- .../secrets/providers/AzureHelper.scala | 25 +++++++++++-------- 2 files changed, 16 insertions(+), 11 deletions(-) diff --git a/project/Settings.scala b/project/Settings.scala index 464fccb..65ef1bf 100644 --- a/project/Settings.scala +++ b/project/Settings.scala @@ -192,7 +192,7 @@ object Settings extends Dependencies { targetDir.mkdirs() val propertiesFileChanged = createPomPropertiesIfChanged(groupId, artifactId, version, targetDir) - if(propertiesFileChanged) { + if (propertiesFileChanged) { createPomXml(log, targetDir, pomUrl) } } diff --git a/secret-provider/src/main/scala/io/lenses/connect/secrets/providers/AzureHelper.scala b/secret-provider/src/main/scala/io/lenses/connect/secrets/providers/AzureHelper.scala index 2be46a9..6cc5c49 100644 --- a/secret-provider/src/main/scala/io/lenses/connect/secrets/providers/AzureHelper.scala +++ b/secret-provider/src/main/scala/io/lenses/connect/secrets/providers/AzureHelper.scala @@ -10,13 +10,17 @@ import com.azure.core.credential.TokenCredential import com.azure.identity.ClientSecretCredentialBuilder import com.azure.identity.DefaultAzureCredentialBuilder import com.azure.security.keyvault.secrets.SecretClient +import com.azure.security.keyvault.secrets.models.SecretProperties import com.typesafe.scalalogging.StrictLogging import io.lenses.connect.secrets.config.AzureProviderSettings +import io.lenses.connect.secrets.connect +import io.lenses.connect.secrets.connect.Encoding.Encoding import io.lenses.connect.secrets.connect._ import org.apache.kafka.connect.errors.ConnectException import java.nio.file.FileSystems import java.time.OffsetDateTime +import scala.jdk.CollectionConverters.MapHasAsScala import scala.util.Failure import scala.util.Success import scala.util.Try @@ -37,16 +41,7 @@ trait AzureHelper extends StrictLogging { val value = secret.getValue val props = secret.getProperties - // check the file-encoding - val encoding = - Encoding.withoutHyphensInsensitiveOpt( - Option(props.getTags) - .map(_.getOrDefault(FILE_ENCODING, Encoding.UTF8.toString)) - .getOrElse(Encoding.UTF8.toString) - .toUpperCase, - ) - - val content = encoding match { + val content = retrieveEncodingFromTags(props) match { case Encoding.UTF8 => value @@ -86,6 +81,16 @@ trait AzureHelper extends StrictLogging { ) } + private def retrieveEncodingFromTags(props: SecretProperties): connect.Encoding.Value = + // check the file-encoding + { + for { + propsMap <- Option(props.getTags.asScala) + fileEncodingFromPropsMap <- propsMap.get(FILE_ENCODING) + enc <- Encoding.withoutHyphensInsensitiveOpt(fileEncodingFromPropsMap) + } yield enc + }.getOrElse(Encoding.UTF8) + // setup azure credentials def createCredentials(settings: AzureProviderSettings): TokenCredential = {