projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add Hypnotic + Mesmer variants
[vchess.git]
/
server
/
models
/
User.js
diff --git
a/server/models/User.js
b/server/models/User.js
index
edb3c06
..
655012d
100644
(file)
--- a/
server/models/User.js
+++ b/
server/models/User.js
@@
-2,10
+2,11
@@
const db = require("../utils/database");
const genToken = require("../utils/tokenGenerator");
const params = require("../config/parameters");
const sendEmail = require('../utils/mailer');
const genToken = require("../utils/tokenGenerator");
const params = require("../config/parameters");
const sendEmail = require('../utils/mailer');
+const { exec } = require("child_process");
/*
* Structure:
/*
* Structure:
- *
_
id: integer
+ * id: integer
* name: varchar
* email: varchar
* loginToken: token on server only
* name: varchar
* email: varchar
* loginToken: token on server only
@@
-13,10
+14,11
@@
const sendEmail = require('../utils/mailer');
* sessionToken: token in cookies for authentication
* notify: boolean (send email notifications for corr games)
* created: datetime
* sessionToken: token in cookies for authentication
* notify: boolean (send email notifications for corr games)
* created: datetime
- *
newsRead: datetime
+ *
bio: text
*/
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
+39,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);
@@
-58,6
+60,16
@@
const UserModel = {
});
},
});
},
+ getBio: function(id, cb) {
+ db.serialize(function() {
+ const query =
+ "SELECT bio " +
+ "FROM Users " +
+ "WHERE id = " + id;
+ db.get(query, cb);
+ });
+ },
+
/////////
// MODIFY
/////////
// MODIFY
@@
-71,13
+83,13
@@
const UserModel = {
});
},
});
},
- set
NewsRead: function(id
) {
+ set
Bio: function(id, bio
) {
db.serialize(function() {
const query =
"UPDATE Users " +
db.serialize(function() {
const query =
"UPDATE Users " +
- "SET
newsRead = " + Date.now() + "
" +
+ "SET
bio = ?
" +
"WHERE id = " + id;
"WHERE id = " + id;
- db.run(query);
+ db.run(query
, bio
);
});
},
});
},
@@
-97,7
+109,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);
@@
-129,7
+141,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);
});
},
@@
-160,14
+172,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;