-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
85 lines (71 loc) · 2.32 KB
/
server.js
File metadata and controls
85 lines (71 loc) · 2.32 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
require('dotenv').config();
const express = require('express');
const mysql = require('mysql');
const nodemailer = require('nodemailer');
const cors = require('cors');
const app = express();
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cors());
const PORT = process.env.PORT;
// // Transporter sécurisé (utiliser des variables d'environnement)
const transporter = nodemailer.createTransport({
host: "smtp.gmail.com",
port: 587,
secure: false,
auth: {
user: process.env.EMAIL_USER,
pass: process.env.EMAIL_PASS
}
});
// Connexion MySQL avec pool de connexions
const pool = mysql.createPool({
connectionLimit: 10,
host: "localhost",
user: "root",
password: "",
database: "temp_hum_db"
});
// Route pour insérer des données et envoyer un email
app.post('/temperature-humidite', async (req, res) => {
const { humidity, temperature } = req.body;
console.log(humidity);
if (!humidity || !temperature) {
return res.status(400).json({ error: "Données invalides" });
}
const sql = "INSERT INTO temp_humidy_table (humidity, temperature) VALUES (?, ?)";
pool.query(sql, [humidity, temperature], (error, results) => {
if (error) {
console.error(error);
return res.status(500).json({ error: "Erreur lors de l'insertion" });
}
// // Préparation de l'email
const mailOptions = {
from: process.env.EMAIL_USER,
to: 'nomenjanaharycelestin33@gmail.com',
subject: 'Humidité et Température',
text: `Humidité: ${humidity}, Température: ${temperature}`
};
transporter.sendMail(mailOptions, (error, info) => {
if (error) {
console.error("Erreur d'envoi d'email :", error);
} else {
console.log('Email envoyé: ' + info.response);
}
});
res.json({ message: "Données insérées avec succès" });
});
});
// Route pour récupérer les données
app.get('/temperature-humidite/', (req, res) => {
const sql = "SELECT humidity, temperature FROM temp_humidy_table";
pool.query(sql, (error, results) => {
if (error) {
console.error(error);
return res.status(500).json({ error: "Erreur de récupération" });
}
res.json(results);
});
});
// Écoute sur le port défini
app.listen(PORT, () => console.log(`Serveur en cours d'exécution sur le port ${PORT}`));