From d6f79366f1cb782f57fdadac6b551c8e93f4ba82 Mon Sep 17 00:00:00 2001 From: Nikolas Falco Date: Wed, 12 Jul 2023 01:41:03 +0200 Subject: [PATCH] CQI Use more generic interface to handle credentials in RegistryHelper --- .../nodejs/configfiles/RegistryHelper.java | 25 +++++++++++-------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/src/main/java/jenkins/plugins/nodejs/configfiles/RegistryHelper.java b/src/main/java/jenkins/plugins/nodejs/configfiles/RegistryHelper.java index ef2895c..ca06516 100644 --- a/src/main/java/jenkins/plugins/nodejs/configfiles/RegistryHelper.java +++ b/src/main/java/jenkins/plugins/nodejs/configfiles/RegistryHelper.java @@ -32,6 +32,7 @@ import java.net.MalformedURLException; import java.net.URL; +import java.nio.charset.StandardCharsets; import java.util.Collection; import java.util.Collections; import java.util.HashMap; @@ -44,14 +45,13 @@ import com.cloudbees.plugins.credentials.CredentialsProvider; import com.cloudbees.plugins.credentials.common.StandardCredentials; -import com.cloudbees.plugins.credentials.common.StandardUsernamePasswordCredentials; +import com.cloudbees.plugins.credentials.common.UsernamePasswordCredentials; import com.cloudbees.plugins.credentials.domains.DomainRequirement; import com.cloudbees.plugins.credentials.domains.URIRequirementBuilder; import edu.umd.cs.findbugs.annotations.CheckForNull; import edu.umd.cs.findbugs.annotations.NonNull; import edu.umd.cs.findbugs.annotations.Nullable; -import edu.umd.cs.findbugs.annotations.SuppressFBWarnings; import hudson.Util; import hudson.model.Run; import hudson.util.Secret; @@ -122,7 +122,6 @@ public String fillRegistry(String npmrcContent, Map * @return the updated version of the {@code npmrcContent} with the registry * credentials added */ - @SuppressFBWarnings(value = "DM_DEFAULT_ENCODING", justification = "npm auth_token could not support base64 UTF-8 char encoding") public String fillRegistry(String npmrcContent, Map registry2Credentials, boolean npm9Format) { Npmrc npmrc = new Npmrc(); npmrc.from(npmrcContent); @@ -147,12 +146,14 @@ public String fillRegistry(String npmrcContent, Map // the _auth directive seems not be considered for scoped registry // only authToken or username/password works - if (credentials instanceof StandardUsernamePasswordCredentials) { - String passwordValue = Base64.encodeBase64String(Secret.toString(((StandardUsernamePasswordCredentials)credentials).getPassword()).getBytes()); - npmrc.set(compose(registryPrefix, NPM_SETTINGS_USER), ((StandardUsernamePasswordCredentials)credentials).getUsername()); + if (credentials instanceof UsernamePasswordCredentials) { + UsernamePasswordCredentials usernamePassowrd = (UsernamePasswordCredentials) credentials; + String passwordValue = Base64.encodeBase64String(Secret.toString(usernamePassowrd.getPassword()).getBytes(StandardCharsets.UTF_8)); + npmrc.set(compose(registryPrefix, NPM_SETTINGS_USER), usernamePassowrd.getUsername()); npmrc.set(compose(registryPrefix, NPM_SETTINGS_PASSWORD), passwordValue); } else if (credentials instanceof StringCredentials) { - String tokenValue = Secret.toString(((StringCredentials)credentials).getSecret()); + StringCredentials stringCredentials = (StringCredentials) credentials; + String tokenValue = Secret.toString(stringCredentials.getSecret()); npmrc.set(compose(registryPrefix, NPM_SETTINGS_AUTHTOKEN), tokenValue); } } @@ -164,12 +165,14 @@ public String fillRegistry(String npmrcContent, Map npmrc.set(NPM_SETTINGS_REGISTRY, registry.getUrl()); if (credentials != null) { npmrc.set(compose(registryPrefix, NPM_SETTINGS_ALWAYS_AUTH), credentials != null); - if (credentials instanceof StandardUsernamePasswordCredentials) { - String authValue = ((StandardUsernamePasswordCredentials)credentials).getUsername() + ':' + Secret.toString(((StandardUsernamePasswordCredentials)credentials).getPassword()); - authValue = Base64.encodeBase64String(authValue.getBytes()); + if (credentials instanceof UsernamePasswordCredentials) { + UsernamePasswordCredentials usernamePassowrd = (UsernamePasswordCredentials) credentials; + String authValue = usernamePassowrd.getUsername() + ':' + Secret.toString(usernamePassowrd.getPassword()); + authValue = Base64.encodeBase64String(authValue.getBytes(StandardCharsets.UTF_8)); npmrc.set(compose(registryPrefix, NPM_SETTINGS_AUTH), authValue); } else if (credentials instanceof StringCredentials) { - String tokenValue = Secret.toString(((StringCredentials)credentials).getSecret()); + StringCredentials stringCredentials = (StringCredentials) credentials; + String tokenValue = Secret.toString(stringCredentials.getSecret()); npmrc.set(compose(registryPrefix, NPM_SETTINGS_AUTHTOKEN), tokenValue); } }