diff --git a/pom.xml b/pom.xml
index 9be75db6..ac44c0f3 100644
--- a/pom.xml
+++ b/pom.xml
@@ -67,7 +67,7 @@
com.opencsv
opencsv
- 4.6
+ 5.7.1
diff --git a/src/main/java/com/cwctravel/hudson/plugins/extended_choice_parameter/ExtendedChoiceParameterDefinition.java b/src/main/java/com/cwctravel/hudson/plugins/extended_choice_parameter/ExtendedChoiceParameterDefinition.java
index 55701a98..645cc77c 100644
--- a/src/main/java/com/cwctravel/hudson/plugins/extended_choice_parameter/ExtendedChoiceParameterDefinition.java
+++ b/src/main/java/com/cwctravel/hudson/plugins/extended_choice_parameter/ExtendedChoiceParameterDefinition.java
@@ -19,6 +19,8 @@
import java.net.URI;
import java.net.URISyntaxException;
import java.net.URL;
+import java.nio.charset.StandardCharsets;
+import java.nio.file.Files;
import java.security.DigestInputStream;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
@@ -39,6 +41,9 @@
import javax.servlet.ServletException;
+import com.opencsv.CSVParser;
+import com.opencsv.CSVParserBuilder;
+import com.opencsv.CSVReaderBuilder;
import org.acegisecurity.Authentication;
import org.acegisecurity.context.SecurityContextHolder;
import org.apache.commons.codec.digest.DigestUtils;
@@ -137,10 +142,7 @@ public FormValidation doCheckPropertyFile(@QueryParameter final String propertyF
}
property.execute();
}
- catch(MalformedURLException e) {
- return FormValidation.warning(Messages.ExtendedChoiceParameterDefinition_PropertyFileDoesntExist(), propertyFile);
- }
- catch(BuildException e) {
+ catch(MalformedURLException | BuildException e) {
return FormValidation.warning(Messages.ExtendedChoiceParameterDefinition_PropertyFileDoesntExist(), propertyFile);
}
@@ -762,22 +764,20 @@ private Binding getGroovyBinding() {
private synchronized GroovyShell getGroovyShell(String groovyClasspath) {
if(groovyShell == null) {
- Jenkins jenkins = Jenkins.getInstance();
- if(jenkins != null) {
- ClassLoader cl = jenkins.getPluginManager().uberClassLoader;
+ Jenkins jenkins = Jenkins.get();
+ ClassLoader cl = jenkins.getPluginManager().uberClassLoader;
- if(cl == null) {
- cl = Thread.currentThread().getContextClassLoader();
- }
-
- CompilerConfiguration compilerConfiguration = new CompilerConfiguration();
- if(!StringUtils.isBlank(groovyClasspath)) {
- compilerConfiguration.setClasspath(groovyClasspath);
- }
+ if(cl == null) {
+ cl = Thread.currentThread().getContextClassLoader();
+ }
- Binding groovyBinding = getGroovyBinding();
- groovyShell = new GroovyShell(cl, groovyBinding, compilerConfiguration);
+ CompilerConfiguration compilerConfiguration = new CompilerConfiguration();
+ if(!StringUtils.isBlank(groovyClasspath)) {
+ compilerConfiguration.setClasspath(groovyClasspath);
}
+
+ Binding groovyBinding = getGroovyBinding();
+ groovyShell = new GroovyShell(cl, groovyBinding, compilerConfiguration);
}
else {
if(!StringUtils.isBlank(groovyClasspath)) {
@@ -837,10 +837,10 @@ private void setBindings(GroovyShell shell, String bindings) throws IOException
}
}
- Jenkins instance = Jenkins.getInstance();
+ Jenkins instance = Jenkins.get();
shell.setProperty("jenkins", instance);
- if(projectName != null && instance != null) {
+ if(projectName != null) {
AbstractProject, ?> project = (AbstractProject, ?>)instance.getItem(projectName);
shell.setProperty("currentProject", project);
}
@@ -939,10 +939,11 @@ Map> calculateChoicesByDropdownId() throws Exception {
String resolvedPropertyFile = expandVariables(propertyFile);
File file = new File(resolvedPropertyFile);
List fileLines = Collections.emptyList();
+ CSVParser csvParser = new CSVParserBuilder().withSeparator('\t').build();
if(file.isFile()) {
CSVReader csvReader = null;
try {
- csvReader = new CSVReader(new InputStreamReader(new FileInputStream(file), "UTF-8"), '\t');
+ csvReader = new CSVReaderBuilder(new InputStreamReader(Files.newInputStream(file.toPath()), StandardCharsets.UTF_8)).withCSVParser(csvParser).build();
fileLines = csvReader.readAll();
}
finally {
@@ -953,7 +954,7 @@ Map> calculateChoicesByDropdownId() throws Exception {
URL propertyFileUrl = new URL(resolvedPropertyFile);
CSVReader csvReader = null;
try {
- csvReader = new CSVReader(new InputStreamReader(propertyFileUrl.openStream(), "UTF-8"), '\t');
+ csvReader = new CSVReaderBuilder(new InputStreamReader(propertyFileUrl.openStream(), StandardCharsets.UTF_8)).withCSVParser(csvParser).build();
fileLines = csvReader.readAll();
}
finally {