Skip to content

Commit

Permalink
Moved subscription validation into subscriber service.
Browse files Browse the repository at this point in the history
  • Loading branch information
dhochbaum-dcp committed Oct 29, 2024
1 parent 1508f49 commit 98554ab
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 48 deletions.
45 changes: 0 additions & 45 deletions server/src/_utils/validate-subscriptions.ts

This file was deleted.

4 changes: 1 addition & 3 deletions server/src/subscriber/subscriber.controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,12 @@ import { ConfigService } from "../config/config.service";
import { SubscriberService } from "./subscriber.service";
import { Request } from "express";
import validateEmail from "../_utils/validate-email";
import validateSubscriptions from "../_utils/validate-subscriptions";

@Controller()
export class SubscriberController {
apiKey = "";
list = "";
sendgridEnvironment = "";
validCustomFieldValues = [1];

constructor(
private readonly config: ConfigService,
Expand All @@ -30,7 +28,7 @@ export class SubscriberController {
return;
}

if(!validateSubscriptions(request.body.subscriptions)) {
if(!this.subscriberService.validateSubscriptions(request.body.subscriptions)) {
response.status(400).send({
error: "Invalid list of subscriptions."
})
Expand Down
59 changes: 59 additions & 0 deletions server/src/subscriber/subscriber.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,13 @@ import { Injectable, Res } from "@nestjs/common";
import { ConfigService } from "../config/config.service";
import { Client } from "@sendgrid/client";
import crypto from 'crypto';
const validCustomFieldNames = ["K01", "K02", "K03", "K04", "K05", "K06", "K07", "K08", "K09", "K10", "K11", "K12", "K13", "K14", "K15", "K16", "K17", "K18", "X01", "X02", "X03", "X04", "X05", "X06", "X07", "X08", "X09", "X10", "X11", "X12", "M01", "M02", "M03", "M04", "M05", "M06", "M07", "M08", "M09", "M10", "M11", "M12", "Q01", "Q02", "Q03", "Q04", "Q05", "Q06", "Q07", "Q08", "Q09", "Q10", "Q11", "Q12", "Q13", "Q14", "R01", "R02", "R03", "CW"] as const;
export type CustomFieldNameTuple = typeof validCustomFieldNames;
type CustomFieldName = CustomFieldNameTuple[number];

const validCustomFieldValues = [1] as const;
export type CustomFieldValueTuple = typeof validCustomFieldValues;
type CustomFieldValue = CustomFieldValueTuple[number];


type HttpMethod = 'get'|'GET'|'post'|'POST'|'put'|'PUT'|'patch'|'PATCH'|'delete'|'DELETE';
Expand All @@ -23,6 +30,11 @@ export class SubscriberService {
this.sendgridEnvironmentIdVariable = `zap_${this.config.get("SENDGRID_ENVIRONMENT")}_id`;
}

/**
* Find a user by their email address.
* @param {string} email
* @returns {object}
*/
async findByEmail(email: string) {
const searchRequest = {
url: "/v3/marketing/contacts/search/emails",
Expand All @@ -40,6 +52,15 @@ export class SubscriberService {
return {isError: true, ...error};
}
}

/**
* Add a user.
* @param {string} email - The user's email address
* @param {string} list - The email list to which we will add the user
* @param {string} environment - Staging or production
* @param {object} subscriptions - The CDs the user is subscribing to
* @returns {object}
*/
async create(email: string, list: string, environment: string, subscriptions: object, @Res() response) {
const id = crypto.randomUUID();
var custom_fields = Object.entries(subscriptions).reduce((acc, curr) => ({...acc, [`zap_${environment}_${curr[0]}`]: curr[1]}), {[`zap_${environment}_confirmed`]: 0})
Expand All @@ -66,4 +87,42 @@ export class SubscriberService {
return {isError: true, ...error};
}
}

/**
* Validate a list of subscriptions.
* @param {object} subscriptions - The subscriptions to validate.
* @returns {boolean}
*/
validateSubscriptions(subscriptions: object) {
if (!subscriptions)
return false;

if(!(Object.entries(subscriptions).length>0))
return false;

for (const [key, value] of Object.entries(subscriptions)) {
if (!(this.validateSubscriptionKey(key) && this.validateSubscriptionValue(value))) {
return false
}
}
return true;
};

/**
* Validate the id of a subscription.
* @param {string} key - The board id, which corresponds to a custom field name
* @returns {boolean}
*/
private validateSubscriptionKey(key: string): key is CustomFieldName {
return validCustomFieldNames.includes(key as CustomFieldName);
}

/**
* Validate the status of a subscription.
* @param {number} value - The value which determines whether they wish to subscribe to the corresponding list
* @returns {boolean}
*/
private validateSubscriptionValue(value: number): value is CustomFieldValue {
return validCustomFieldValues.includes(value as CustomFieldValue);
}
}

0 comments on commit 98554ab

Please sign in to comment.