budibase/packages/server/src/utilities/usageQuota.js

55 lines
1.6 KiB
JavaScript
Raw Normal View History

2021-09-24 00:25:25 +02:00
// const env = require("../environment")
2021-09-23 23:40:14 +02:00
const { getGlobalDB } = require("@budibase/auth/tenancy")
function getNewQuotaReset() {
return Date.now() + 2592000000
}
exports.Properties = {
ROW: "rows",
UPLOAD: "storage",
VIEW: "views",
USER: "users",
AUTOMATION: "automationRuns",
2021-09-24 00:25:25 +02:00
APPS: "apps",
}
/**
2021-09-23 23:40:14 +02:00
* Given a specified tenantId this will add to the usage object for the specified property.
* @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-23 23:40:14 +02:00
// if (!env.USE_QUOTAS) {
// return
// }
try {
2021-09-24 00:25:25 +02:00
const db = getGlobalDB()
const quota = await db.get("usage_quota")
// TODO: check if the quota needs reset
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
if (quota.usageQuota[property] >= quota.usageLimits[property]) {
throw new Error(
`You have exceeded your usage quota of ${quota.usageLimits[property]} ${property}.`
)
}
// update the usage quotas
await db.put(quota)
} 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
}
}