projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Update code to remove users in tournament DB as well
[vchess.git]
/
server
/
models
/
User.js
diff --git
a/server/models/User.js
b/server/models/User.js
index
37df4e6
..
d62cd76
100644
(file)
--- a/
server/models/User.js
+++ b/
server/models/User.js
@@
-5,7
+5,7
@@
const sendEmail = require('../utils/mailer');
/*
* Structure:
/*
* Structure:
- *
_
id: integer
+ * id: integer
* name: varchar
* email: varchar
* loginToken: token on server only
* name: varchar
* email: varchar
* loginToken: token on server only
@@
-17,6
+17,7
@@
const sendEmail = require('../utils/mailer');
*/
const UserModel = {
*/
const UserModel = {
+
checkNameEmail: function(o) {
return (
(!o.name || !!(o.name.match(/^[\w-]+$/))) &&
checkNameEmail: function(o) {
return (
(!o.name || !!(o.name.match(/^[\w-]+$/))) &&
@@
-37,11
+38,11
@@
const UserModel = {
},
// Find one user by id, name, email, or token
},
// Find one user by id, name, email, or token
- getOne: function(by, value, cb) {
+ getOne: function(by, value,
fields,
cb) {
const delimiter = (typeof value === "string" ? "'" : "");
db.serialize(function() {
const query =
const delimiter = (typeof value === "string" ? "'" : "");
db.serialize(function() {
const query =
- "SELECT
*
" +
+ "SELECT
" + fields + "
" +
"FROM Users " +
"WHERE " + by + " = " + delimiter + value + delimiter;
db.get(query, cb);
"FROM Users " +
"WHERE " + by + " = " + delimiter + value + delimiter;
db.get(query, cb);
@@
-107,7
+108,7
@@
const UserModel = {
query =
"UPDATE Users " +
// Also empty the login token to invalidate future attempts
query =
"UPDATE Users " +
// Also empty the login token to invalidate future attempts
- "SET loginToken = NULL" +
+ "SET loginToken = NULL
, loginTime = NULL
" +
setSessionToken + " " +
"WHERE id = " + id;
db.run(query);
setSessionToken + " " +
"WHERE id = " + id;
db.run(query);
@@
-139,7
+140,7
@@
const UserModel = {
},
tryNotify: function(id, message) {
},
tryNotify: function(id, message) {
- UserModel.getOne("id", id,
(err,
user) => {
+ UserModel.getOne("id", id,
"name, email, notify", (err,
user) => {
if (!err && user.notify) UserModel.notify(user, message);
});
},
if (!err && user.notify) UserModel.notify(user, message);
});
},
@@
-170,14
+171,18
@@
const UserModel = {
}
});
if (toRemove.length > 0) {
}
});
if (toRemove.length > 0) {
+ const remArg = toRemove.join(",");
db.run(
"DELETE FROM Users " +
db.run(
"DELETE FROM Users " +
- "WHERE id IN (" +
toRemove.join(",")
+ ")"
+ "WHERE id IN (" +
remArg
+ ")"
);
);
+ // Update tournament DB:
+ exec(params.tourneyPath + "/dbsync/delete_users.py " + remArg);
}
});
});
}
});
});
- },
-}
+ }
+
+};
module.exports = UserModel;
module.exports = UserModel;