-
Notifications
You must be signed in to change notification settings - Fork 1
/
db.mjs
89 lines (81 loc) · 1.95 KB
/
db.mjs
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
86
87
88
89
import Sequelize from 'sequelize';
export let sequelize;
const host = "localhost";
const port = "5432";
const databaseName = "home";
const login = "postgres";
const password = "";
try {
sequelize = new Sequelize("postgresql://" + login + ":" + password + "@" + host + ":" + port + "/" + databaseName + "?ssl=false", {
logging: false,
idleTimeoutMillis: 10000
});
} catch (e) {
console.log("Database connection error");
}
export const Air = sequelize.define('air', {
date: {
type: Sequelize.DATE,
primaryKey: true
},
temperature: {
type: Sequelize.FLOAT,
allowNull: false
},
humidity: {
type: Sequelize.INTEGER,
allowNull: false
},
pm25: {
type: Sequelize.FLOAT,
allowNull: false
},
level: {
type: Sequelize.INTEGER,
allowNull: true
},
});
export const Airly = sequelize.define('airly', {
date: {
type: Sequelize.DATE,
primaryKey: true
},
temperature: {
type: Sequelize.FLOAT,
allowNull: false
},
humidity: {
type: Sequelize.INTEGER,
allowNull: false
},
pressure: {
type: Sequelize.INTEGER,
allowNull: false
},
pm25: {
type: Sequelize.FLOAT,
allowNull: false
},
pm10: {
type: Sequelize.FLOAT,
allowNull: false
},
pm1: {
type: Sequelize.FLOAT,
allowNull: true
},
});
sequelize.sync();
async function saveToDatabase(purifier, date) {
let humidity = purifier.humidity, pm25 = purifier.pm25, mode = purifier.mode, level = purifier.level,
temperature = purifier.temperature;
let data = {date, temperature: temperature, humidity, pm25, mode, level: level};
try {
await db.Air.create(data);
} catch (e) {
console.log("Database insert error");
}
}
export async function logData(purifier, date) {
await saveToDatabase(purifier, date);
}