forked from cs4241-19a/fp
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabase.js
More file actions
153 lines (138 loc) · 2.91 KB
/
Copy pathdatabase.js
File metadata and controls
153 lines (138 loc) · 2.91 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
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
/*
* CS 4241 Final Project - Database component
* by Terry Hearst, Demi Karavoussianis, Kyle Reese, and Tom White
*/
const Sequelize = require('sequelize');
// Simple file based db using an ORM
const sequelize = new Sequelize({
dialect: 'sqlite',
storage: 'database.lite',
pool: {
max: 5,
min: 0,
aquire: 3000,
idle: 1000
}
});
class User extends Sequelize.Model{}
class Task extends Sequelize.Model{}
//-------------
// Databases
//-------------
// Table model for the User database
User.init({
id: {
type: Sequelize.INTEGER,
primaryKey: true,
autoIncrement: true,
},
salt: {
type: Sequelize.STRING,
allowNull: false,
},
hash: {
type: Sequelize.STRING,
allowNull: false,
},
username: {
type: Sequelize.STRING,
allowNull: false,
}
},{sequelize: sequelize, modelName: 'user'});
// Table model for the Task database
Task.init({
id: {
type: Sequelize.INTEGER,
primaryKey: true,
autoIncrement: true,
},
userId: {
type: Sequelize.INTEGER,
references: {
model: User,
key: 'id',
deferrable: Sequelize.Deferrable.INITIALLY_IMMEDIATE
},
},
title: {
type: Sequelize.STRING,
allowNull: false,
},
priority: {
type: Sequelize.STRING,
allowNull: false,
},
completed: {
type: Sequelize.BOOLEAN,
allowNull: false,
},
dueDate: {
type: Sequelize.STRING,
allowNull: false,
},
uhoh: {
type: Sequelize.BOOLEAN,
allowNull: false,
},
description: {
type: Sequelize.STRING,
allowNull: false,
},
doLater: {
type: Sequelize.BOOLEAN,
allowNull: false,
}
},{sequelize: sequelize, modelName: 'task'});
//startDB function
function startDB(){
return sequelize.authenticate()
.then(() => {
Task.belongsTo(User);
User.sync();
Task.sync();
})
}
//-----------
// Helpers
//-----------
//getUser
function getUser(username){
return User.findOne({
where: {username: username}
});
}
//getUserTasks
function getUserTasks(username){
return getUser(username).then((user) => {
return Task.findAll({
where: {userId: user.id}
});
})
}
//createUser
function createUser(username, salt, hash){
return User.create({
username: username,
salt: salt,
hash: hash,
});
}
//createTask
function createTask(object){
return Task.create(object);
}
//updateTask
function updateTask(taskId, object){
return Task.findOne({
where: {id: taskId}
}).then(result => {
return result.update(object)
}).catch(err => console.log(err))
}
//deleteTask
function deleteTask(taskId){
return Task.destroy({
where: {id: taskId}
})
}
module.exports = {startDB, getUser, getUserTasks, createUser, createTask, updateTask, deleteTask}