Switched to using HikariCP for connection pool
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				Locusworks Team/eight-track/pipeline/head This commit looks good
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	Locusworks Team/eight-track/pipeline/head This commit looks good
				
			This commit is contained in:
		
							
								
								
									
										32
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								pom.xml
									
									
									
									
									
								
							| @@ -14,16 +14,16 @@ | ||||
| 	</organization> | ||||
|  | ||||
| 	<scm> | ||||
| 		<url>git@gitea.locusworks.net:Locusworks/eight-track.git</url> | ||||
| 		<url>ssh://gitea@gitea.locusworks.net:7999/locusworks/eight-track.git</url> | ||||
| 	</scm> | ||||
|  | ||||
| 	<properties> | ||||
| 		<flyway.version>6.1.3</flyway.version> | ||||
| 		<mariadb.version>2.5.2</mariadb.version> | ||||
| 		<hibernate.version>5.4.10.Final</hibernate.version> | ||||
| 		<spring.version>5.2.2.RELEASE</spring.version> | ||||
| 		<spring.boot.version>2.2.2.RELEASE</spring.boot.version> | ||||
| 		<spring.data.version>2.2.2.RELEASE</spring.data.version> | ||||
| 		<flyway.version>6.4.2</flyway.version> | ||||
| 		<mysql.version>8.0.20</mysql.version> | ||||
| 		<hibernate.version>5.4.16.Final</hibernate.version> | ||||
| 		<spring.version>5.2.6.RELEASE</spring.version> | ||||
| 		<spring.boot.version>2.3.0.RELEASE</spring.boot.version> | ||||
| 		<spring.data.version>2.3.0.RELEASE</spring.data.version> | ||||
| 		<jackson.version>2.10.1</jackson.version> | ||||
| 		<log4j.version>2.12.1</log4j.version> | ||||
| 		<slf4j.version>1.7.28</slf4j.version> | ||||
| @@ -116,7 +116,7 @@ | ||||
| 				<artifactId>flyway-maven-plugin</artifactId> | ||||
| 				<version>${flyway.version}</version> | ||||
| 				<configuration> | ||||
| 					<url>jdbc:mariadb://localhost:3306/</url> | ||||
| 					<url>jdbc:mysql://localhost:3306/</url> | ||||
| 					<outOfOrder>false</outOfOrder> | ||||
| 					<schemas> | ||||
| 						<schema>eighttrack</schema> | ||||
| @@ -128,9 +128,9 @@ | ||||
| 				</configuration> | ||||
| 				<dependencies> | ||||
| 					<dependency> | ||||
| 						<groupId>org.mariadb.jdbc</groupId> | ||||
| 						<artifactId>mariadb-java-client</artifactId> | ||||
| 						<version>${mariadb.version}</version> | ||||
| 						<groupId>mysql</groupId> | ||||
| 						<artifactId>mysql-connector-java</artifactId> | ||||
| 						<version>${mysql.version}</version> | ||||
| 					</dependency> | ||||
| 				</dependencies> | ||||
| 			</plugin> | ||||
| @@ -184,17 +184,11 @@ | ||||
| 			<version>${flyway.version}</version> | ||||
| 		</dependency> | ||||
|  | ||||
| 		<dependency> | ||||
| 			<groupId>org.mariadb.jdbc</groupId> | ||||
| 			<artifactId>mariadb-java-client</artifactId> | ||||
| 			<version>${mariadb.version}</version> | ||||
| 		</dependency> | ||||
|  | ||||
| 		<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --> | ||||
| 		<dependency> | ||||
| 			<groupId>mysql</groupId> | ||||
| 			<artifactId>mysql-connector-java</artifactId> | ||||
| 			<version>8.0.18</version> | ||||
| 			<version>${mysql.version}</version> | ||||
| 		</dependency> | ||||
|  | ||||
| 		<dependency> | ||||
| @@ -206,7 +200,7 @@ | ||||
| 		<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-c3p0 --> | ||||
| 		<dependency> | ||||
| 			<groupId>org.hibernate</groupId> | ||||
| 			<artifactId>hibernate-c3p0</artifactId> | ||||
| 			<artifactId>hibernate-hikaricp</artifactId> | ||||
| 			<version>${hibernate.version}</version> | ||||
| 		</dependency> | ||||
|  | ||||
|   | ||||
| @@ -30,21 +30,19 @@ package net.locusworks.discord.eighttrack.database.config; | ||||
| import java.util.LinkedHashMap; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
| import java.util.Properties; | ||||
| import java.util.TimeZone; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| import javax.sql.DataSource; | ||||
|  | ||||
| import org.apache.commons.lang3.StringUtils; | ||||
| import org.mariadb.jdbc.MariaDbDataSource; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.boot.jdbc.DataSourceBuilder; | ||||
| import org.springframework.context.annotation.Bean; | ||||
| import org.springframework.context.annotation.Primary; | ||||
| import org.springframework.stereotype.Component; | ||||
| import com.mchange.v2.c3p0.ComboPooledDataSource; | ||||
| import net.locusworks.discord.eighttrack.services.ConfigurationService; | ||||
|  | ||||
| @Primary | ||||
| @@ -76,35 +74,22 @@ public class EightTrackDataSource { | ||||
|    */ | ||||
|   @Bean | ||||
|   public DataSource dataSource() throws Exception { | ||||
|     return getDataSource(false); | ||||
|     logger.debug("Getting datasource"); | ||||
|     return getDataSource(confService.getDatabaseUsername(),  | ||||
|         confService.getDatabasePassword(), | ||||
|         "/eighttrack"); | ||||
|   } | ||||
|    | ||||
|   @Bean | ||||
|   public DataSource flywayDataSource() throws Exception { | ||||
|     logger.debug("Logging in with flyway for migrations"); | ||||
|      | ||||
|     String user = confService.getDatabaseRootUsername(); | ||||
|     String passwd = confService.getDatabaseRootPassword(); | ||||
|      | ||||
|     String url = String.format("jdbc:mariadb://%s:%d?user=%s&password=%s",  | ||||
|         confService.getDatabaseHost(), confService.getDatabasePort(), | ||||
|         user, passwd); | ||||
|      | ||||
|     MariaDbDataSource mariadbDS = new MariaDbDataSource(url); | ||||
|      | ||||
|     return mariadbDS; | ||||
|     return getDataSource(confService.getDatabaseRootUsername(),  | ||||
|         confService.getDatabaseRootPassword(), | ||||
|         ""); | ||||
|   } | ||||
|    | ||||
|   private DataSource getDataSource(Boolean isFlyway) throws Exception { | ||||
|     logger.debug("Getting datasource"); | ||||
|      | ||||
|     String user = confService.getDatabaseUsername(); | ||||
|     String passwd = confService.getDatabasePassword(); | ||||
|      | ||||
|     Properties props = new Properties(); | ||||
|     props.setProperty("user", user); | ||||
|     props.setProperty("password", passwd); | ||||
|      | ||||
|   private DataSource getDataSource(String user, String passwd, String db) throws Exception { | ||||
|     List<String> params = mysqlProperties | ||||
|         .entrySet() | ||||
|         .stream() | ||||
| @@ -114,22 +99,19 @@ public class EightTrackDataSource { | ||||
|     String host = confService.getDatabaseHost(); | ||||
|     int port = confService.getDatabasePort(); | ||||
|      | ||||
|     String url = String.format(JNDI_STRING, host, port, "/eighttrack"); | ||||
|     String url = String.format(JNDI_STRING, host, port, db); | ||||
|      | ||||
|     url = String.format("%s?%s", url, StringUtils.join(params, "&")); | ||||
|      | ||||
|     logger.debug("Database connection string: %s", url); | ||||
|      | ||||
|     ComboPooledDataSource cpds = new ComboPooledDataSource(); | ||||
|     cpds.setDriverClass(DRIVER); | ||||
|     cpds.setJdbcUrl(url); | ||||
|     cpds.setUser(user); | ||||
|     cpds.setPassword(passwd); | ||||
|     cpds.setMinPoolSize(5); | ||||
|     cpds.setMaxPoolSize(100); | ||||
|     cpds.setAcquireIncrement(10); | ||||
|      | ||||
|     return cpds; | ||||
|     return DataSourceBuilder | ||||
|         .create() | ||||
|         .username(user) | ||||
|         .password(passwd) | ||||
|         .url(url) | ||||
|         .driverClassName(DRIVER) | ||||
|         .build(); | ||||
|   } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -44,7 +44,6 @@ import net.locusworks.discord.eighttrack.database.entities.GuildPlaylist; | ||||
| import net.locusworks.discord.eighttrack.database.entities.GuildPlaylistSong; | ||||
| import net.locusworks.discord.eighttrack.database.entities.GuildSong; | ||||
| import net.locusworks.discord.eighttrack.events.playlist.AbstractPlaylistEventHandler; | ||||
| import net.locusworks.discord.eighttrack.handlers.GuildMusicHandler; | ||||
| import net.locusworks.discord.eighttrack.services.RepositoryService; | ||||
|  | ||||
| @Component | ||||
|   | ||||
| @@ -42,7 +42,6 @@ import net.locusworks.discord.eighttrack.database.entities.GuildPlaylist; | ||||
| import net.locusworks.discord.eighttrack.database.entities.GuildPlaylistSong; | ||||
| import net.locusworks.discord.eighttrack.database.entities.GuildSong; | ||||
| import net.locusworks.discord.eighttrack.events.playlist.AbstractPlaylistEventHandler; | ||||
| import net.locusworks.discord.eighttrack.handlers.GuildMusicHandler; | ||||
| import net.locusworks.discord.eighttrack.handlers.ReactionHandler; | ||||
| import net.locusworks.discord.eighttrack.listeners.ReactionListener; | ||||
| import net.locusworks.discord.eighttrack.services.RepositoryService; | ||||
|   | ||||
| @@ -36,7 +36,6 @@ import net.locusworks.discord.eighttrack.database.entities.GuildPlaylist; | ||||
| import net.locusworks.discord.eighttrack.database.entities.GuildPlaylistSong; | ||||
| import net.locusworks.discord.eighttrack.database.entities.GuildSong; | ||||
| import net.locusworks.discord.eighttrack.events.playlist.AbstractPlaylistEventHandler; | ||||
| import net.locusworks.discord.eighttrack.handlers.GuildMusicHandler; | ||||
| import net.locusworks.discord.eighttrack.services.RepositoryService; | ||||
|  | ||||
| @Component | ||||
|   | ||||
| @@ -67,7 +67,7 @@ public class AESService { | ||||
|     AESService service = new AESService(); | ||||
|     service.init(); | ||||
|      | ||||
|     System.out.println(service.encrypt("zeGAPgbH9HFbqmjRjmwzUDKv")); | ||||
|     System.out.println(service.encrypt("yqwAK!H5KAc0d2xWdN6*S0w4")); | ||||
|      | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -59,8 +59,7 @@ public class GuildMusicService { | ||||
|   private void init() { | ||||
|     logger = ApplicationLoggerFactory.getLogger(GuildMusicService.class); | ||||
|     for (DiscordGuild dg : guildRepoService.getGuildRepo().findAll()) { | ||||
|       GuildMusicHandler gmh = new GuildMusicHandler(dg.getGuildId(), guildRepoService); | ||||
|       gmh.accept((id) -> handlerMap.remove(id)); | ||||
|       GuildMusicHandler gmh = createMusicHandler(dg.getGuildId()); | ||||
|       handlerMap.put(dg.getGuildId(), gmh); | ||||
|     } | ||||
|   } | ||||
| @@ -112,11 +111,20 @@ public class GuildMusicService { | ||||
|    | ||||
|   public GuildMusicHandler getMusicHandler(Long guildId) { | ||||
|     if (!handlerMap.containsKey(guildId)) { | ||||
|       GuildMusicHandler gmh = new GuildMusicHandler(guildId, guildRepoService); | ||||
|       gmh.accept((id) -> handlerMap.remove(id)); | ||||
|       GuildMusicHandler gmh = createMusicHandler(guildId); | ||||
|       handlerMap.put(guildId, gmh); | ||||
|     } | ||||
|      | ||||
|     return handlerMap.get(guildId); | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * @param guildId | ||||
|    * @return | ||||
|    */ | ||||
|   private GuildMusicHandler createMusicHandler(Long guildId) { | ||||
|     GuildMusicHandler gmh = new GuildMusicHandler(guildId, guildRepoService); | ||||
|     gmh.accept((id) -> handlerMap.remove(id)); | ||||
|     return gmh; | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -9,10 +9,6 @@ | ||||
|     <class>net.locusworks.discord.eighttrack.database.entities.GuildPlaylistSong</class> | ||||
|     <class>net.locusworks.discord.eighttrack.database.entities.Log</class> | ||||
|     <properties> | ||||
|       <property name="javax.persistence.jdbc.url" value="jdbc:mariadb://devops.locusworks.net:3306/eighttrack"/> | ||||
|       <property name="javax.persistence.jdbc.user" value="root"/> | ||||
|       <property name="javax.persistence.jdbc.driver" value="org.mariadb.jdbc.Driver"/> | ||||
|       <property name="javax.persistence.jdbc.password" value="0a0wNt6aX4e66LNhA5uKLdnnN"/> | ||||
|     </properties> | ||||
|   </persistence-unit> | ||||
| </persistence> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| dbAdmin=root | ||||
| dbAdminPassword=gSkjsvZbQTQtogOrPYqorCuuzp4WUpGFVtPYtMVj47U= | ||||
| dbAdminPassword=bDNuBX0IqflafBFBfr10MQkdGgamC3UeZ0GcsWUWeCI= | ||||
| dbUser=eighttrackAdmin | ||||
| dbUserPassword=RaamWDMgA2p09R3kAiKHqauu6mmKU2HLQ4nAfEGMNOs= | ||||
| dbHost=localhost | ||||
|   | ||||
		Reference in New Issue
	
	Block a user