-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdb.js
More file actions
49 lines (41 loc) · 1.51 KB
/
db.js
File metadata and controls
49 lines (41 loc) · 1.51 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
const { Pool } = require('pg');
const pool = new Pool({
host: process.env.DB_HOST || 'localhost',
port: process.env.DB_PORT || 26257,
user: process.env.DB_USER || 'root',
password: process.env.DB_PASSWORD || '',
database: process.env.DB_NAME || 'freshcart',
ssl: process.env.DB_HOST && process.env.DB_HOST.includes('cockroachlabs.cloud')
? { rejectUnauthorized: false }
: false
});
pool.on('connect', () => {
console.log('Connected to CockroachDB');
});
pool.on('error', (err) => {
console.error('Database error:', err);
});
const testConnection = async () => {
try {
const result = await pool.query('SELECT version()');
const version = result.rows[0].version.substring(0, 50);
console.log(`Database version: ${version}...`);
try {
const nodes = await pool.query('SELECT node_id, address FROM crdb_internal.gossip_nodes ORDER BY node_id');
console.log(`Cluster nodes: ${nodes.rows.length}`);
nodes.rows.forEach(node => {
console.log(` - Node ${node.node_id}: ${node.address}`);
});
} catch (err) {
console.log('Running on CockroachDB Serverless');
}
const tables = await pool.query("SELECT table_name FROM information_schema.tables WHERE table_schema = 'public'");
const table_list = tables.rows.map(t => t.table_name).join(', ') || 'none';
console.log(`Tables: ${table_list}`);
return true;
} catch (error) {
console.error('Connection failed:', error.message);
return false;
}
};
module.exports = { pool, testConnection };