mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Fixed invalid Offers from throwing when reading
closes https://github.com/TryGhost/Product/issues/3675
refs c98bf80248
As part of our architecture guidelines Repository implementations should protect
against invalid or malformed data in persistence. We do not want read operations
of Entities to throw because of such data. For some fields that bad data can be
fixed or handled in the constructor or static create factory method and replaced
with valid data, others will cause the factory to throw.
This means that Repositories should catch these errors and exclude those
entities from their results. We log the errors in Sentry so that we have
visibility on the state of bad data in DBs
This commit is contained in:
parent
84e6026408
commit
5e3470a3a1
1 changed files with 28 additions and 20 deletions
|
@ -2,6 +2,8 @@ const {flowRight} = require('lodash');
|
|||
const {mapKeyValues, mapQuery} = require('@tryghost/mongo-utils');
|
||||
const DomainEvents = require('@tryghost/domain-events');
|
||||
const {Offer} = require('@tryghost/members-offers');
|
||||
const sentry = require('../../../shared/sentry');
|
||||
const logger = require('@tryghost/logging');
|
||||
|
||||
const statusTransformer = mapKeyValues({
|
||||
key: {
|
||||
|
@ -99,25 +101,31 @@ class OfferBookshelfRepository {
|
|||
const count = await this.OfferRedemptionModel.where({offer_id: json.id}).count('id', {
|
||||
transacting: options.transacting
|
||||
});
|
||||
return Offer.create({
|
||||
id: json.id,
|
||||
name: json.name,
|
||||
code: json.code,
|
||||
display_title: json.portal_title,
|
||||
display_description: json.portal_description,
|
||||
type: json.discount_type === 'amount' ? 'fixed' : json.discount_type,
|
||||
amount: json.discount_amount,
|
||||
cadence: json.interval,
|
||||
currency: json.currency,
|
||||
duration: json.duration,
|
||||
duration_in_months: json.duration_in_months,
|
||||
redemptionCount: count,
|
||||
status: json.active ? 'active' : 'archived',
|
||||
tier: {
|
||||
id: json.product.id,
|
||||
name: json.product.name
|
||||
}
|
||||
}, null);
|
||||
try {
|
||||
return await Offer.create({
|
||||
id: json.id,
|
||||
name: json.name,
|
||||
code: json.code,
|
||||
display_title: json.portal_title,
|
||||
display_description: json.portal_description,
|
||||
type: json.discount_type === 'amount' ? 'fixed' : json.discount_type,
|
||||
amount: json.discount_amount,
|
||||
cadence: json.interval,
|
||||
currency: json.currency,
|
||||
duration: json.duration,
|
||||
duration_in_months: json.duration_in_months,
|
||||
redemptionCount: count,
|
||||
status: json.active ? 'active' : 'archived',
|
||||
tier: {
|
||||
id: json.product.id,
|
||||
name: json.product.name
|
||||
}
|
||||
}, null);
|
||||
} catch (err) {
|
||||
logger.error(err);
|
||||
sentry.captureException(err);
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -173,7 +181,7 @@ class OfferBookshelfRepository {
|
|||
|
||||
const offers = models.map(model => this.mapToOffer(model, mapOptions));
|
||||
|
||||
return Promise.all(offers);
|
||||
return (await Promise.all(offers)).filter(offer => offer !== null);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Add table
Reference in a new issue