rittenhop-dev/versions/5.94.2/node_modules/@tryghost/limit-service/lib/date-utils.js
2024-09-23 19:40:12 -04:00

38 lines
1.3 KiB
JavaScript

const {DateTime} = require('luxon');
const {IncorrectUsageError} = require('@tryghost/errors');
const messages = {
invalidInterval: 'Invalid interval specified. Only "month" value is accepted.'
};
const SUPPORTED_INTERVALS = ['month'];
/**
* Calculates the start of the last period (billing, cycle, etc.) based on the start date
* and the interval at which the cycle renews.
*
* @param {String} startDate - date in ISO 8601 format (https://en.wikipedia.org/wiki/ISO_8601)
* @param {('month')} interval - currently only supports 'month' value, in the future might support 'year', etc.
*
* @returns {String} - date in ISO 8601 format (https://en.wikipedia.org/wiki/ISO_8601) of the last period start
*/
const lastPeriodStart = (startDate, interval) => {
if (interval === 'month') {
const startDateISO = DateTime.fromISO(startDate, {zone: 'UTC'});
const now = DateTime.now().setZone('UTC');
const fullPeriodsPast = Math.floor(now.diff(startDateISO, 'months').months);
const lastPeriodStartDate = startDateISO.plus({months: fullPeriodsPast});
return lastPeriodStartDate.toISO();
}
throw new IncorrectUsageError({
message: messages.invalidInterval
});
};
module.exports = {
lastPeriodStart,
SUPPORTED_INTERVALS
};