You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The Underlying Issue:
The original code had a document-based database (mongoDB) implemented as such - one document for each subscription entry, which contained a mailingList and an email. To make queries easier, we don't want one database document for each entry but instead per mailing list.
The Fix:
In PR #7 , we decided to instead add pushToSet in the update function whenever a user subscribes - this updates the original collection (associated with the mailingList), and adds the email address. This also ensures that no user duplicates are added to the same mailingList, since Mongo automatically deduplicates the data.
Bug
The Issue:
Our subscription-schema.ts file doesn't have support for an list of emails - just a string per email. Therefore, when we try to insert it/update the array, it doesn't work. To make this more challenging, the current SubscriptionValidator is also used before insertions to the database - this means that we need an entirely new validator.
The Proposed Solution:
Rename the SubscriptionValidator to something like SubscriptionSchemaValidator, and change the import (in database.ts)
Add a new validator named SubscriptionValidator, for input requests - this validator should contain a similar schema to the current SubscriptionValidator.
Add an array field to the database (string array), and remove the email field.
Expected Behavior
By the end of it all, we should have 2 validators:
SubscriptionValidator -> checks for mailingList (string) + email (string), we use it to parse incoming POST requests in the router
SubscriptionSchemaValidator -> checks for mailingList (string) + email list (string[]), we use it when inserting into the Mongoose database (see database.ts)
The text was updated successfully, but these errors were encountered:
Context
The Underlying Issue:
The original code had a document-based database (mongoDB) implemented as such - one document for each subscription entry, which contained a mailingList and an email. To make queries easier, we don't want one database document for each entry but instead per mailing list.
The Fix:
In PR #7 , we decided to instead add
pushToSet
in the update function whenever a user subscribes - this updates the original collection (associated with the mailingList), and adds the email address. This also ensures that no user duplicates are added to the same mailingList, since Mongo automatically deduplicates the data.Bug
The Issue:
Our subscription-schema.ts file doesn't have support for an list of emails - just a string per email. Therefore, when we try to insert it/update the array, it doesn't work. To make this more challenging, the current
SubscriptionValidator
is also used before insertions to the database - this means that we need an entirely new validator.The Proposed Solution:
Expected Behavior
By the end of it all, we should have 2 validators:
SubscriptionValidator -> checks for mailingList (string) + email (string), we use it to parse incoming POST requests in the router
SubscriptionSchemaValidator -> checks for mailingList (string) + email list (string[]), we use it when inserting into the Mongoose database (see database.ts)
The text was updated successfully, but these errors were encountered: