-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstorage.js
207 lines (193 loc) · 5.42 KB
/
storage.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
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
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
import sqlite3 from "sqlite3";
const db = new sqlite3.Database("data.db");
/** @typedef {{ pid: number, pnid: string, fc: string, hash: string, show: 0 | 1 }} User */
db.run(`CREATE TABLE IF NOT EXISTS users (
pid INTEGER,
pnid TEXT,
fc TEXT,
hash TEXT,
show INTEGER
);`);
/*
0 - from skipped
1 - from sent
2 - to sent (unused)
3 - both sent, match
*/
/** @typedef { 0 | 1 | 3 } SwipeType */
/** @typedef {{ id: number?, from_u: string, to_u: string, type: SwipeType }} Swipe */
db.run(`CREATE TABLE IF NOT EXISTS swipes (
id INTEGER PRIMARY KEY,
from_u TEXT,
to_u TEXT,
type INTEGER
);`);
/**
* Pushes a new user to the database.
*
* @param {User} user The user data
*/
export function pushUser(user) {
return new Promise(resolve => {
db.run(`INSERT INTO users (pid, pnid, fc, hash, show)
VALUES (?, ?, ?, ?, 1);`, [user.pid, user.pnid, user.fc, user.hash], resolve);
});
}
/**
* Updadtes a user's show preference in the database.
*
* @param {string} pnid The user's PNID
* @param {0 | 1} show Whether to show this user or not
*/
export function updateUser(pnid, show) {
return new Promise(resolve => {
db.run(`UPDATE users SET show = ?
WHERE pnid = ?;`, [show, pnid], resolve);
});
}
/**
* Gets a user from the database by PNID.
*
* @param {string} pnid The user PNID
* @returns {Promise<User>} The user object
*/
export function getUserByPNID(pnid) {
return new Promise((resolve, reject) => {
db.get(`SELECT * FROM users WHERE pnid = ?;`, [pnid], (err, data) => {
if(err) reject(err);
else resolve(data);
});
});
}
/**
* Pushes a new swipe to the database.
*
* @param {Swipe} swipe The swipe data
*/
export function pushSwipe(swipe) {
return new Promise(async resolve => {
if(await getSwipeByPNIDs(swipe.from_u, swipe.to_u)) return resolve(null);
db.run(`INSERT INTO swipes (from_u, to_u, type)
VALUES (?, ?, ?);`, [swipe.from_u, swipe.to_u, swipe.type], resolve);
});
}
/**
* Gets a swipe from the database by its ID.
*
* @param {number} id The swipe ID
* @returns {Promise<Swipe>} The swipe object
*/
export function getSwipeByID(id) {
return new Promise((resolve, reject) => {
db.get(`SELECT * FROM swipes WHERE id = ?;`, [id], (err, data) => {
if(err) reject(err);
else resolve(data);
});
});
}
/**
* Gets a swipe from the database by its PNIDs.
*
* @param {string} from_u The sender
* @param {string} to_u The recievepent
* @returns {Promise<Swipe>} The swipe object
*/
export function getSwipeByPNIDs(from_u, to_u) {
return new Promise((resolve, reject) => {
db.get(`SELECT * FROM swipes WHERE from_u = ? AND to_u = ?;`, [from_u, to_u], (err, data) => {
if(err) reject(err);
else resolve(data);
});
});
}
/**
* Updadtes a swipe's type in the database.
*
* @param {number} id The swipe ID
* @param {SwipeType} type The swipe type
*/
export function updateSwipe(id, type) {
return new Promise(resolve => {
db.run(`UPDATE swipes SET type = ?
WHERE id = ?;`, [type, id], resolve);
});
}
/**
* Gets matched swipes.
*
* @param {string} pnid The user PNID
* @returns {Promise<Swipe[]>} The swipes
*/
export function getMatches(pnid) {
return new Promise((resolve, reject) => {
db.all(`SELECT * FROM swipes
WHERE to_u = ? AND type = 3
UNION SELECT * FROM swipes
WHERE from_u = ? AND type = 3;`, [pnid, pnid], (err, data) => {
if(err) reject(err);
else resolve(data);
});
});
}
/**
* Gets skipped swipes.
*
* @param {string} pnid The user PNID
* @returns {Promise<Swipe[]>} The swipes
*/
export function getSkipped(pnid) {
return new Promise((resolve, reject) => {
db.all(`SELECT * FROM swipes
WHERE from_u = ? AND type = 0;`, [pnid], (err, data) => {
if(err) reject(err);
else resolve(data);
});
});
}
/**
* Removes a swipe.
*
* @param {number} id The swipe ID
*/
export function removeSwipe(id) {
return new Promise(resolve => {
db.run(`DELETE FROM swipes WHERE id = ?;`, [id], resolve);
});
}
/**
* Recommends users to a specific user.
*
* @param {string} user The user PNID
* @return {Promise<User[]>} Recommended users
*/
export function recommendUsers(user) {
return new Promise((resolve, reject) => {
db.all(`SELECT u.*
FROM swipes s
INNER JOIN users u ON s.from_u = u.pnid
WHERE s.to_u = ? AND s.type = 1 AND u.show = 1;`, [user], (err, data) => {
if(err) reject(err);
else if(data.length < 10) db.all(`SELECT *
FROM users u
WHERE u.pnid NOT IN (
SELECT s.to_u
FROM swipes s
WHERE s.from_u = ?
) AND u.pnid NOT IN (
SELECT s.from_u
FROM swipes s
WHERE s.to_u = ? AND s.type IN (0, 3)
) AND u.pnid != ? AND u.show = 1
ORDER BY RANDOM()
LIMIT 10;`, [user, user, user], (err2, data2) => {
if(err2) reject(err2);
else {
const dataf = data.map(x => x.pnid);
data2 = data2.filter(x => !dataf.includes(x.pnid));
resolve(data.concat(data2).slice(0, 10));
}
})
else resolve(data);
});
});
}