2021-04-07 12:33:16 +02:00
|
|
|
exports.StaticDatabases = {
|
2021-04-16 19:09:34 +02:00
|
|
|
GLOBAL: {
|
|
|
|
name: "global-db",
|
2021-04-07 12:33:16 +02:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
const DocumentTypes = {
|
|
|
|
USER: "us",
|
2021-04-13 14:26:13 +02:00
|
|
|
APP: "app",
|
2021-04-07 12:33:16 +02:00
|
|
|
}
|
|
|
|
|
2021-04-08 12:20:37 +02:00
|
|
|
exports.DocumentTypes = DocumentTypes
|
|
|
|
|
2021-04-07 12:33:16 +02:00
|
|
|
const UNICODE_MAX = "\ufff0"
|
|
|
|
const SEPARATOR = "_"
|
|
|
|
|
2021-04-13 14:26:13 +02:00
|
|
|
exports.SEPARATOR = SEPARATOR
|
|
|
|
|
2021-04-07 12:33:16 +02:00
|
|
|
/**
|
|
|
|
* Generates a new user ID based on the passed in email.
|
|
|
|
* @param {string} email The email which the ID is going to be built up of.
|
|
|
|
* @returns {string} The new user ID which the user doc can be stored under.
|
|
|
|
*/
|
|
|
|
exports.generateUserID = email => {
|
|
|
|
return `${DocumentTypes.USER}${SEPARATOR}${email}`
|
|
|
|
}
|
|
|
|
|
2021-04-12 19:31:58 +02:00
|
|
|
exports.getEmailFromUserID = userId => {
|
|
|
|
return userId.split(`${DocumentTypes.USER}${SEPARATOR}`)[1]
|
|
|
|
}
|
|
|
|
|
2021-04-07 12:33:16 +02:00
|
|
|
/**
|
|
|
|
* Gets parameters for retrieving users, this is a utility function for the getDocParams function.
|
|
|
|
*/
|
|
|
|
exports.getUserParams = (email = "", otherProps = {}) => {
|
2021-04-09 16:11:49 +02:00
|
|
|
if (!email) {
|
|
|
|
email = ""
|
|
|
|
}
|
2021-04-07 12:33:16 +02:00
|
|
|
return {
|
|
|
|
...otherProps,
|
|
|
|
startkey: `${DocumentTypes.USER}${SEPARATOR}${email}`,
|
|
|
|
endkey: `${DocumentTypes.USER}${SEPARATOR}${email}${UNICODE_MAX}`,
|
|
|
|
}
|
|
|
|
}
|