2021-08-05 10:59:08 +02:00
|
|
|
const { getDB } = require("../db")
|
2021-10-07 16:49:26 +02:00
|
|
|
const { SEPARATOR, StaticDatabases, DocumentTypes } = require("../db/constants")
|
2021-08-05 10:59:08 +02:00
|
|
|
const { getTenantId, DEFAULT_TENANT_ID, isMultiTenant } = require("./context")
|
|
|
|
const env = require("../environment")
|
|
|
|
|
|
|
|
const TENANT_DOC = StaticDatabases.PLATFORM_INFO.docs.tenants
|
|
|
|
const PLATFORM_INFO_DB = StaticDatabases.PLATFORM_INFO.name
|
|
|
|
|
|
|
|
exports.addTenantToUrl = url => {
|
|
|
|
const tenantId = getTenantId()
|
|
|
|
|
|
|
|
if (isMultiTenant()) {
|
|
|
|
const char = url.indexOf("?") === -1 ? "?" : "&"
|
|
|
|
url += `${char}tenantId=${tenantId}`
|
|
|
|
}
|
|
|
|
|
|
|
|
return url
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.doesTenantExist = async tenantId => {
|
|
|
|
const db = getDB(PLATFORM_INFO_DB)
|
|
|
|
let tenants
|
|
|
|
try {
|
|
|
|
tenants = await db.get(TENANT_DOC)
|
|
|
|
} catch (err) {
|
|
|
|
// if theres an error the doc doesn't exist, no tenants exist
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
tenants &&
|
|
|
|
Array.isArray(tenants.tenantIds) &&
|
|
|
|
tenants.tenantIds.indexOf(tenantId) !== -1
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.tryAddTenant = async (tenantId, userId, email) => {
|
|
|
|
const db = getDB(PLATFORM_INFO_DB)
|
|
|
|
const getDoc = async id => {
|
|
|
|
if (!id) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
return await db.get(id)
|
|
|
|
} catch (err) {
|
|
|
|
return { _id: id }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
let [tenants, userIdDoc, emailDoc] = await Promise.all([
|
|
|
|
getDoc(TENANT_DOC),
|
|
|
|
getDoc(userId),
|
|
|
|
getDoc(email),
|
|
|
|
])
|
|
|
|
if (!Array.isArray(tenants.tenantIds)) {
|
|
|
|
tenants = {
|
|
|
|
_id: TENANT_DOC,
|
|
|
|
tenantIds: [],
|
|
|
|
}
|
|
|
|
}
|
|
|
|
let promises = []
|
|
|
|
if (userIdDoc) {
|
|
|
|
userIdDoc.tenantId = tenantId
|
|
|
|
promises.push(db.put(userIdDoc))
|
|
|
|
}
|
|
|
|
if (emailDoc) {
|
|
|
|
emailDoc.tenantId = tenantId
|
2021-09-17 14:41:22 +02:00
|
|
|
emailDoc.userId = userId
|
2021-08-05 10:59:08 +02:00
|
|
|
promises.push(db.put(emailDoc))
|
|
|
|
}
|
|
|
|
if (tenants.tenantIds.indexOf(tenantId) === -1) {
|
|
|
|
tenants.tenantIds.push(tenantId)
|
|
|
|
promises.push(db.put(tenants))
|
|
|
|
}
|
|
|
|
await Promise.all(promises)
|
|
|
|
}
|
|
|
|
|
2021-09-27 20:12:41 +02:00
|
|
|
exports.getGlobalDBName = (tenantId = null) => {
|
2021-08-05 10:59:08 +02:00
|
|
|
// tenant ID can be set externally, for example user API where
|
|
|
|
// new tenants are being created, this may be the case
|
|
|
|
if (!tenantId) {
|
|
|
|
tenantId = getTenantId()
|
|
|
|
}
|
|
|
|
|
|
|
|
let dbName
|
|
|
|
if (tenantId === DEFAULT_TENANT_ID) {
|
|
|
|
dbName = StaticDatabases.GLOBAL.name
|
|
|
|
} else {
|
|
|
|
dbName = `${tenantId}${SEPARATOR}${StaticDatabases.GLOBAL.name}`
|
|
|
|
}
|
2021-09-27 20:12:41 +02:00
|
|
|
return dbName
|
|
|
|
}
|
2021-08-05 10:59:08 +02:00
|
|
|
|
2021-09-27 20:12:41 +02:00
|
|
|
exports.getGlobalDB = (tenantId = null) => {
|
|
|
|
const dbName = exports.getGlobalDBName(tenantId)
|
2021-08-05 10:59:08 +02:00
|
|
|
return getDB(dbName)
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.lookupTenantId = async userId => {
|
|
|
|
const db = getDB(StaticDatabases.PLATFORM_INFO.name)
|
|
|
|
let tenantId = env.MULTI_TENANCY ? DEFAULT_TENANT_ID : null
|
|
|
|
try {
|
|
|
|
const doc = await db.get(userId)
|
|
|
|
if (doc && doc.tenantId) {
|
|
|
|
tenantId = doc.tenantId
|
|
|
|
}
|
|
|
|
} catch (err) {
|
|
|
|
// just return the default
|
|
|
|
}
|
|
|
|
return tenantId
|
|
|
|
}
|
2021-10-06 16:15:46 +02:00
|
|
|
|
|
|
|
// lookup, could be email or userId, either will return a doc
|
|
|
|
exports.getTenantUser = async identifier => {
|
|
|
|
const db = getDB(PLATFORM_INFO_DB)
|
|
|
|
try {
|
|
|
|
return await db.get(identifier)
|
|
|
|
} catch (err) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
}
|
2021-10-07 16:49:26 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Given an app ID this will attempt to retrieve the tenant ID from it.
|
|
|
|
* @return {null|string} The tenant ID found within the app ID.
|
|
|
|
*/
|
|
|
|
exports.getTenantIDFromAppID = appId => {
|
|
|
|
if (!appId) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
const split = appId.split(SEPARATOR)
|
|
|
|
const hasDev = split[1] === DocumentTypes.DEV
|
|
|
|
if ((hasDev && split.length === 3) || (!hasDev && split.length === 2)) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
if (hasDev) {
|
|
|
|
return split[2]
|
|
|
|
} else {
|
|
|
|
return split[1]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.isUserInAppTenant = (appId, user = null) => {
|
|
|
|
let userTenantId
|
|
|
|
if (user) {
|
|
|
|
userTenantId = user.tenantId || DEFAULT_TENANT_ID
|
|
|
|
} else {
|
|
|
|
userTenantId = getTenantId()
|
|
|
|
}
|
|
|
|
const tenantId = exports.getTenantIDFromAppID(appId) || DEFAULT_TENANT_ID
|
|
|
|
return tenantId === userTenantId
|
|
|
|
}
|