-
Notifications
You must be signed in to change notification settings - Fork 0
/
db.js
102 lines (95 loc) · 2.06 KB
/
db.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
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
90
91
92
93
94
95
96
97
98
99
100
101
102
const { Sequelize, DataTypes } = require("sequelize");
const sequelize = new Sequelize({
dialect: 'sqlite',
storage: './database.sqlite'
});
const Diff = sequelize.define('Diff', {
LinkID: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true,
},
LinkLanguageUUID: {
type: DataTypes.STRING(255),
allowNull: false,
},
Diff: {
type: DataTypes.JSON,
allowNull: false,
},
DID: {
type: DataTypes.STRING(255),
allowNull: false,
},
ServerRecordTimestamp: {
type: DataTypes.DATE,
allowNull: false,
}
});
const AgentSyncState = sequelize.define('AgentSyncState', {
ID: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true,
},
DID: {
type: DataTypes.STRING(255),
allowNull: false,
},
LinkLanguageUUID: {
type: DataTypes.STRING(255),
allowNull: false,
},
Timestamp: {
type: DataTypes.DATE,
allowNull: false,
},
});
const AgentStatus = sequelize.define('AgentStatus', {
ID: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true,
},
DID: {
type: DataTypes.STRING(255),
allowNull: false,
},
LinkLanguageUUID: {
type: DataTypes.STRING(255),
allowNull: false,
},
Status: {
type: DataTypes.JSON,
allowNull: true, // Adjust as needed
}
})
const AgentExpression = sequelize.define('AgentExpression', {
DID: {
type: DataTypes.STRING(255),
allowNull: false,
primaryKey: true,
},
Expression: {
type: DataTypes.JSON,
allowNull: false,
},
Timestamp: {
type: DataTypes.DATE,
allowNull: false,
},
})
async function initDatabase() {
await Diff.sync();
await AgentSyncState.sync();
await AgentStatus.sync();
await AgentExpression.sync();
}
module.exports = {
sequelize,
initDatabase,
Diff,
AgentSyncState,
AgentStatus,
AgentExpression
}