-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdb.js
More file actions
executable file
·53 lines (47 loc) · 1.7 KB
/
db.js
File metadata and controls
executable file
·53 lines (47 loc) · 1.7 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
// db.js
const sqlite3 = require('sqlite3').verbose();
const path = require('path');
const fs = require('fs');
const dataDir = path.join(process.cwd(), 'data');
if (!fs.existsSync(dataDir)) {
fs.mkdirSync(dataDir, { recursive: true, mode: 0o777 });
}
const dbPath = path.join(dataDir, 'fish.db');
// Utilisation de drapeaux explicites pour l'ouverture
const db = new sqlite3.Database(dbPath, sqlite3.OPEN_READWRITE | sqlite3.OPEN_CREATE, (err) => {
if (err) {
console.error('❌ Erreur SQLITE_CANTOPEN:', err.message);
console.error('Vérifiez les droits sur:', dbPath);
} else {
// Mode WAL : Indispensable dans Docker pour éviter les "Database is locked"
db.run("PRAGMA journal_mode = WAL;");
console.log('✅ DB connectée avec succès sur:', dbPath);
}
});
function initTables() {
db.serialize(() => { // serialize assure que les tables sont créées dans l'ordre
db.run(`
CREATE TABLE IF NOT EXISTS users (
token TEXT PRIMARY KEY,
hashed_ip TEXT NOT NULL,
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
last_seen DATETIME DEFAULT CURRENT_TIMESTAMP
)
`);
db.run(`
CREATE TABLE IF NOT EXISTS conversations (
id INTEGER PRIMARY KEY AUTOINCREMENT,
token TEXT NOT NULL,
message TEXT NOT NULL,
response TEXT,
latitude REAL,
longitude REAL,
timezone TEXT,
hashed_ip TEXT NOT NULL,
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
FOREIGN KEY (token) REFERENCES users(token)
)
`);
});
}
module.exports = { db, initTables };