-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathknexfile.js
54 lines (46 loc) · 1.07 KB
/
knexfile.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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// Update with your config settings.
require('dotenv').config();
/**
* @type { Object.<string, import("knex").Knex.Config> }
*/
const pg = require('pg');
if (process.env.DATABASE_URL) {
pg.defaults.ssl = { rejectUnauthorized: false };
}
const sharedConfig = {
client: 'pg',
migrations: { directory: './data/migrations' },
seeds: { directory: './data/seeds' },
};
// For SQLITE Dev Testing
const sqliteConfig = {
useNullAsDefault: true,
migrations: { directory: './data/migrations' },
pool: {
afterCreate: (conn, done) => conn.run('PRAGMA foreign_keys = ON', done),
},
};
module.exports = {
development: {
...sharedConfig,
connection: process.env.DEV_DATABASE_URL,
},
testing: {
...sharedConfig,
connection: process.env.TESTING_DATABASE_URL,
},
production: {
...sharedConfig,
connection: process.env.DATABASE_URL,
pool: { min: 2, max: 10 },
},
// For SQLITE Development (we shouldn't use this though)
dev_sqlite: {
client: 'sqlite3',
connection: {
filename: './data/dev.db3',
},
...sqliteConfig,
seeds: { directory: './data/seeds' },
},
};