0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Add API verification trigger with new filter

no issue

Previous API verification trigger didn't work because the way filters work also changed. Re-implemented with a new filter.
This commit is contained in:
Sam Lord 2022-02-03 15:02:33 +00:00
parent 4fde1d2667
commit bf9070f945
3 changed files with 62 additions and 1 deletions

View file

@ -36,6 +36,9 @@ module.exports = class EventRepository {
if (filters['data.created_at']) { if (filters['data.created_at']) {
options.filter.push(filters['data.created_at'].replace(/data.created_at:/g, 'created_at:')); options.filter.push(filters['data.created_at'].replace(/data.created_at:/g, 'created_at:'));
} }
if (filters['data.source']) {
options.filter.push(filters['data.source'].replace(/data.source:/g, 'source:'));
}
if (filters['data.member_id']) { if (filters['data.member_id']) {
options.filter.push(filters['data.member_id'].replace(/data.member_id:/g, 'member_id:')); options.filter.push(filters['data.member_id'].replace(/data.member_id:/g, 'member_id:'));
} }

View file

@ -1,4 +1,6 @@
const errors = require('@tryghost/errors'); const errors = require('@tryghost/errors');
const DomainEvents = require('@tryghost/domain-events');
const {MemberSubscribeEvent} = require('@tryghost/member-events');
const messages = { const messages = {
emailVerificationNeeded: `We're hard at work processing your import. To make sure you get great deliverability on a list of that size, we'll need to enable some extra features for your account. A member of our team will be in touch with you by email to review your account make sure everything is configured correctly so you're ready to go.`, emailVerificationNeeded: `We're hard at work processing your import. To make sure you get great deliverability on a list of that size, we'll need to enable some extra features for your account. A member of our team will be in touch with you by email to review your account make sure everything is configured correctly so you're ready to go.`,
@ -34,6 +36,24 @@ class VerificationTrigger {
this._membersStats = membersStats; this._membersStats = membersStats;
this._Settings = Settings; this._Settings = Settings;
this._eventRepository = eventRepository; this._eventRepository = eventRepository;
DomainEvents.subscribe(MemberSubscribeEvent, async (event) => {
if (event.data.source === 'api' && isFinite(this._configThreshold)) {
const createdAt = new Date();
createdAt.setDate(createdAt.getDate() - 30);
const events = await this._eventRepository.getNewsletterSubscriptionEvents({}, {
'data.source': 'data.source:api',
'data.created_at': `data.created_at:>${createdAt.toISOString().replace('T', ' ').substring(0, 19)}`
});
if (events.meta.pagination.total > this._configThreshold) {
await this.startVerificationProcess({
amountImported: events.meta.pagination.total,
throwOnTrigger: false
});
}
}
});
} }
async getImportThreshold() { async getImportThreshold() {

View file

@ -3,6 +3,8 @@
const sinon = require('sinon'); const sinon = require('sinon');
require('./utils'); require('./utils');
const VerificationTrigger = require('../lib/verification-trigger'); const VerificationTrigger = require('../lib/verification-trigger');
const DomainEvents = require('@tryghost/domain-events');
const {MemberSubscribeEvent} = require('@tryghost/member-events');
describe('Import threshold', function () { describe('Import threshold', function () {
it('Creates a threshold based on config', async function () { it('Creates a threshold based on config', async function () {
@ -152,4 +154,40 @@ describe('Email verification flow', function () {
amountImported: 10 amountImported: 10
}); });
}); });
});
it('Triggers when a number of API events are dispatched', async function () {
const emailStub = sinon.stub().resolves(null);
const settingsStub = sinon.stub().resolves(null);
const eventStub = sinon.stub().resolves({
meta: {
pagination: {
total: 10
}
}
});
new VerificationTrigger({
configThreshold: 2,
Settings: {
edit: settingsStub
},
isVerified: () => false,
isVerificationRequired: () => false,
sendVerificationEmail: emailStub,
eventRepository: {
getNewsletterSubscriptionEvents: eventStub
}
});
DomainEvents.dispatch(MemberSubscribeEvent.create({
memberId: 'hello!',
source: 'api'
}, new Date()));
eventStub.callCount.should.eql(1);
eventStub.lastCall.lastArg.should.have.property('data.source');
eventStub.lastCall.lastArg.should.have.property('data.created_at');
eventStub.lastCall.lastArg['data.source'].should.eql('data.source:api');
eventStub.lastCall.lastArg['data.created_at'].should.startWith('data.created_at:>');
});
});