Skip to content

Commit

Permalink
Accept com.mysql.cj.util.TimeUtil in addition to com.mysql.jdbc.TimeUtil
Browse files Browse the repository at this point in the history
  • Loading branch information
hiroyuki-sato committed Aug 10, 2024
1 parent d5bb81c commit 4a17d05
Showing 1 changed file with 38 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
import java.sql.DriverManager;
import java.sql.SQLException;
import java.time.ZoneId;
import java.util.Arrays;
import java.util.List;
import java.util.Optional;
import java.util.Properties;
import java.util.concurrent.atomic.AtomicReference;
Expand Down Expand Up @@ -159,20 +161,20 @@ private void loadTimeZoneMappings()
// Here implements a workaround as as workaround.
Field f = null;
try {
Class<?> timeUtilClass = Class.forName("com.mysql.jdbc.TimeUtil");
Class<?> timeUtilClass = getTimeUtilClass();
f = timeUtilClass.getDeclaredField("timeZoneMappings");
f.setAccessible(true);

Properties timeZoneMappings = (Properties) f.get(null);
if (timeZoneMappings == null) {
timeZoneMappings = new Properties();
synchronized (timeUtilClass) {
timeZoneMappings.load(this.getClass().getResourceAsStream("/com/mysql/jdbc/TimeZoneMapping.properties"));
loadTimezoneMappings(timeZoneMappings);
}
f.set(null, timeZoneMappings);
}
}
catch (ClassNotFoundException | IllegalAccessException | NoSuchFieldException | IOException e) {
catch (IllegalAccessException | NoSuchFieldException e) {
throw new RuntimeException(e);
}
finally {
Expand Down Expand Up @@ -252,7 +254,40 @@ private static Class<? extends java.sql.Driver> loadJdbcDriverClassForName(final
{
return (Class<? extends java.sql.Driver>) Class.forName(className);
}
private Class<?> getTimeUtilClass() {
Class<?> timeUtilClass;
List<String> timeUtilClassNames = Arrays.asList(
"com.mysql.jdbc.TimeUtil", // Connector/J v5.X
"com.mysql.cj.util.TimeUtil" // Connector/J v8.X
);

for (String name : timeUtilClassNames) {
try {
timeUtilClass = Class.forName(name);
return timeUtilClass;
} catch (ClassNotFoundException e) {
// do nothing.
}
}
throw new ConfigException("Can't find TimeUtil Class");
}

private void loadTimezoneMappings(Properties timeZoneMappings) {
List<String> timeZoneResources = Arrays.asList(
"/com/mysql/jdbc/TimeZoneMapping.properties", // Connector/J v5.X
"/com/mysql/cj/util/TimeZoneMapping.properties" // Connector/J v8.X
);

for (String resource : timeZoneResources) {
try {
timeZoneMappings.load(this.getClass().getResourceAsStream(resource));
return;
} catch (IOException | NullPointerException e) {
// do nothing.
}
}
throw new ConfigException("Can't find Timezone mapping property file.");
}
private static final AtomicReference<Class<? extends java.sql.Driver>> mysqlJdbcDriver = new AtomicReference<>();

private static final Logger logger = LoggerFactory.getLogger(MySQLInputPlugin.class);
Expand Down

0 comments on commit 4a17d05

Please sign in to comment.