diff --git a/pom.xml b/pom.xml
index 23db87d..de8577b 100644
--- a/pom.xml
+++ b/pom.xml
@@ -25,6 +25,11 @@
mariadb-java-client
3.3.3
+
+ io.github.cdimascio
+ dotenv-java
+ 3.0.0
+
diff --git a/src/main/java/fr/tetelie/crawler/Crawler.java b/src/main/java/fr/tetelie/crawler/Crawler.java
index 9156ef0..05cbd44 100644
--- a/src/main/java/fr/tetelie/crawler/Crawler.java
+++ b/src/main/java/fr/tetelie/crawler/Crawler.java
@@ -17,23 +17,11 @@ public class Crawler {
public static void main(String[] args) {
+ new DatabaseConfig();
+ boolean isConnected = DatabaseConfig.getInstance().connect();
- String dbUrl = "jdbc:mariadb://localhost:3306/Crawler";
- String user = "root";
- String password = "";
-
- System.out.println("Tentative de connexion à la base de données...");
-
- try (Connection connection = DriverManager.getConnection(dbUrl, user, password)) {
- if (connection != null) {
- System.out.println("✅ SUCCÈS : Connexion établie avec brio !");
- System.out.println("Serveur distant : " + connection.getMetaData().getDatabaseProductName());
- }
- } catch (SQLException e) {
- System.err.println("❌ ÉCHEC : Impossible de se connecter.");
- System.err.println("Erreur : " + e.getMessage());
- }
+ if(!isConnected){return;};
String url = "https://www.amazon.fr/Victool-temp%C3%A9rature-professionnel-r%C3%A9paration-%C3%A9lectronique/dp/B0FP2D7TBY/?_encoding=UTF8&pd_rd_w=UWXHj&content-id=amzn1.sym.5633189b-a269-4b24-8a80-52a48568a326%3Aamzn1.symc.752cde0b-d2ce-4cce-9121-769ea438869e&pf_rd_p=5633189b-a269-4b24-8a80-52a48568a326&pf_rd_r=G56TKFERTQ9WS62C7WY4&pd_rd_wg=mtTBQ&pd_rd_r=519dfa29-c58c-41b3-89ca-4d01e27bfc2e&ref_=pd_hp_d_atf_ci_mcx_mr_ca_hp_atf_d";
diff --git a/src/main/java/fr/tetelie/crawler/DatabaseConfig.java b/src/main/java/fr/tetelie/crawler/DatabaseConfig.java
new file mode 100644
index 0000000..94be49b
--- /dev/null
+++ b/src/main/java/fr/tetelie/crawler/DatabaseConfig.java
@@ -0,0 +1,54 @@
+package fr.tetelie.crawler;
+
+import io.github.cdimascio.dotenv.Dotenv;
+
+import javax.xml.crypto.Data;
+import java.sql.Connection;
+import java.sql.DriverManager;
+import java.sql.SQLException;
+
+public class DatabaseConfig {
+
+ static DatabaseConfig instance;
+
+ String dbUrl;
+ String dbUser;
+ String dbPass;
+
+ public static DatabaseConfig getInstance() {
+ return instance;
+
+ }
+
+ public DatabaseConfig() {
+
+ instance = this;
+ // Charge le fichier .env
+ Dotenv dotenv = Dotenv.load();
+
+ // Récupère les variables
+ dbUrl = dotenv.get("DB_URL");
+ dbUser = dotenv.get("DB_USER");
+ dbPass = dotenv.get("DB_PASS");
+
+ // Maintenant tu peux utiliser dbPass dans ton DriverManager.getConnection()
+ System.out.println("Configuration chargée avec succès !");
+ }
+
+ public boolean connect()
+ {
+ System.out.println("Tentative de connexion à la base de données...");
+
+ try (Connection connection = DriverManager.getConnection(DatabaseConfig.getInstance().dbUrl, DatabaseConfig.getInstance().dbUser, DatabaseConfig.getInstance().dbPass)) {
+ if (connection != null) {
+ System.out.println("✅ SUCCÈS : Connexion établie avec brio !");
+ System.out.println("Serveur distant : " + connection.getMetaData().getDatabaseProductName());
+ }
+ } catch (SQLException e) {
+ System.err.println("❌ ÉCHEC : Impossible de se connecter.");
+ System.err.println("Erreur : " + e.getMessage());
+ return false;
+ }
+ return true;
+ }
+}