2021-09-27 16:03:48 +02:00
|
|
|
const env = require("../environment")
|
2021-09-23 23:40:14 +02:00
|
|
|
const { getGlobalDB } = require("@budibase/auth/tenancy")
|
2021-09-27 18:35:22 +02:00
|
|
|
const {
|
|
|
|
StaticDatabases,
|
|
|
|
generateNewUsageQuotaDoc,
|
|
|
|
} = require("@budibase/auth/db")
|
2020-10-07 18:56:47 +02:00
|
|
|
|
2020-10-09 12:32:25 +02:00
|
|
|
function getNewQuotaReset() {
|
|
|
|
return Date.now() + 2592000000
|
|
|
|
}
|
2020-10-07 18:56:47 +02:00
|
|
|
|
|
|
|
exports.Properties = {
|
2020-10-09 20:10:28 +02:00
|
|
|
ROW: "rows",
|
2020-10-07 18:56:47 +02:00
|
|
|
UPLOAD: "storage",
|
|
|
|
VIEW: "views",
|
|
|
|
USER: "users",
|
|
|
|
AUTOMATION: "automationRuns",
|
2021-09-24 00:25:25 +02:00
|
|
|
APPS: "apps",
|
2021-09-27 15:57:22 +02:00
|
|
|
EMAILS: "emails",
|
2020-10-07 18:56:47 +02:00
|
|
|
}
|
|
|
|
|
2021-09-27 18:35:22 +02:00
|
|
|
async function getUsageQuotaDoc(db) {
|
|
|
|
let quota
|
|
|
|
try {
|
|
|
|
quota = await db.get(StaticDatabases.PLATFORM_INFO.docs.usageQuota)
|
|
|
|
} catch (err) {
|
|
|
|
// doc doesn't exist. Create it
|
|
|
|
quota = await db.post(generateNewUsageQuotaDoc())
|
|
|
|
}
|
|
|
|
|
|
|
|
return quota
|
|
|
|
}
|
|
|
|
|
2020-10-07 18:56:47 +02:00
|
|
|
/**
|
2021-09-23 23:40:14 +02:00
|
|
|
* Given a specified tenantId this will add to the usage object for the specified property.
|
2020-10-07 18:56:47 +02:00
|
|
|
* @param {string} property The property which is to be added to (within the nested usageQuota object).
|
|
|
|
* @param {number} usage The amount (this can be negative) to adjust the number by.
|
|
|
|
* @returns {Promise<void>} When this completes the API key will now be up to date - the quota period may have
|
|
|
|
* also been reset after this call.
|
|
|
|
*/
|
2021-09-24 00:25:25 +02:00
|
|
|
exports.update = async (property, usage) => {
|
2021-09-27 16:03:48 +02:00
|
|
|
if (!env.USE_QUOTAS) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2020-10-07 18:56:47 +02:00
|
|
|
try {
|
2021-09-24 00:25:25 +02:00
|
|
|
const db = getGlobalDB()
|
2021-09-27 18:35:22 +02:00
|
|
|
const quota = await getUsageQuotaDoc(db)
|
2021-09-27 15:57:22 +02:00
|
|
|
|
|
|
|
// Check if the quota needs reset
|
2021-09-24 00:25:25 +02:00
|
|
|
if (Date.now() >= quota.quotaReset) {
|
|
|
|
quota.quotaReset = getNewQuotaReset()
|
|
|
|
for (let prop of Object.keys(quota.usageQuota)) {
|
|
|
|
quota.usageQuota[prop] = 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// increment the quota
|
|
|
|
quota.usageQuota[property] += usage
|
|
|
|
|
2021-10-04 15:07:10 +02:00
|
|
|
if (quota.usageQuota[property] > quota.usageLimits[property]) {
|
2021-09-24 00:25:25 +02:00
|
|
|
throw new Error(
|
|
|
|
`You have exceeded your usage quota of ${quota.usageLimits[property]} ${property}.`
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
// update the usage quotas
|
|
|
|
await db.put(quota)
|
2020-10-07 18:56:47 +02:00
|
|
|
} catch (err) {
|
2021-09-24 00:25:25 +02:00
|
|
|
console.error(`Error updating usage quotas for ${property}`, err)
|
2020-10-09 22:42:20 +02:00
|
|
|
throw err
|
2020-10-07 18:56:47 +02:00
|
|
|
}
|
|
|
|
}
|