-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathpostgres.js
32 lines (27 loc) · 942 Bytes
/
postgres.js
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
const fs = require("fs");
const SqlCrudAdapter = require("./sql-crud-adapter");
const SurveyStorage = require("./survey-storage");
const readFileSync = filename => fs.readFileSync(filename).toString("utf8");
const dbConfig = {
host: process.env.DATABASE_HOST || "localhost",
port: process.env.DATABASE_PORT || 5432,
database: process.env.DATABASE_DB,
user: process.env.DATABASE_USER,
password: process.env.DATABASE_PASSWORD
? readFileSync(process.env.DATABASE_PASSWORD)
: null
};
const Pool = require('pg').Pool
const pool = new Pool(dbConfig);
function PostgresStorage () {
function queryExecutorFunction() {
if(!!process.env.DATABASE_LOG) {
console.log(arguments[0]);
console.log(arguments[1]);
}
return pool.query.apply(pool, arguments);
}
const dbQueryAdapter = new SqlCrudAdapter(queryExecutorFunction);
return new SurveyStorage(dbQueryAdapter);
}
module.exports = PostgresStorage;