From 9cfda4c0ce8b9b2b65096e11104d0f918c70afaa Mon Sep 17 00:00:00 2001 From: Danial Raza Date: Mon, 29 Jan 2024 06:32:02 +0100 Subject: [PATCH] feat(constants): introduce quote limits --- src/util/constants.ts | 52 +++++++++++++++++++++++++++++++++++++++++++ src/util/helpers.ts | 49 ++++++++++++++++++++-------------------- 2 files changed, 77 insertions(+), 24 deletions(-) diff --git a/src/util/constants.ts b/src/util/constants.ts index 62287cf..4b93531 100644 --- a/src/util/constants.ts +++ b/src/util/constants.ts @@ -1,3 +1,55 @@ +/** + * The name of the API + */ export const NAME = "Quote-It" as const + +/** + * The description of the API + */ export const DESCRIPTION = "Your go-to API for inspiring, and thought-provoking quotes." as const + +/** + * The version of the API + */ export const VERSION = "1.0.0" as const + +/** + * The limits of the quote + */ +export const QUOTE_LIMITS = { + /** + * The minimum length of the author + */ + MinimumAuthorLength: 1, + /** + * The maximum length of the author + */ + MaximumAuthorLength: 30, + + /** + * The minimum length of the category + */ + MinimumCategoryLength: 1, + /** + * The maximum length of the category + */ + MaximumCategoryLength: 20, + + /** + * The minimum length of the submitter + */ + MinimumSubmitterLength: 1, + /** + * The maximum length of the submitter + */ + MaximumSubmitterLength: 30, + + /** + * The minimum length of the text + */ + MinimumTextLength: 1, + /** + * The maximum length of the text + */ + MaximumTextLength: 200, +} as const diff --git a/src/util/helpers.ts b/src/util/helpers.ts index 12edcb3..bd776d9 100644 --- a/src/util/helpers.ts +++ b/src/util/helpers.ts @@ -1,5 +1,6 @@ import Filter from "bad-words" import type { DatabaseQuote, QuoteUnion, QuoteWithCategoriesArray, ValidationError } from "../types/index.js" +import { QUOTE_LIMITS } from "./constants.js" /** * Converts the properties of a quote for the database @@ -45,18 +46,18 @@ export function validateQuote(quote: unknown) { const { author, categories, submitter, text } = quote as Record if (typeof author === "string" || typeof author === "undefined") { - if (typeof author !== "undefined" && author.length < 1) { + if (typeof author !== "undefined" && author.length < QUOTE_LIMITS.MinimumAuthorLength) { errors.push({ - expected: "string.length <= 1", - message: "Expected the author to be at least 1 character", + expected: `string.length <= ${QUOTE_LIMITS.MinimumAuthorLength}`, + message: `Expected the author to be at least ${QUOTE_LIMITS.MinimumAuthorLength} character`, received: `${author.length}`, }) } - if (typeof author !== "undefined" && author.length > 30) { + if (typeof author !== "undefined" && author.length > QUOTE_LIMITS.MaximumAuthorLength) { errors.push({ - expected: "string.length <= 30", - message: "Expected the author to be less than 30 characters", + expected: `string.length <= ${QUOTE_LIMITS.MaximumAuthorLength}`, + message: `Expected the author to be less than ${QUOTE_LIMITS.MaximumAuthorLength} characters`, received: `${author.length}`, }) } @@ -71,18 +72,18 @@ export function validateQuote(quote: unknown) { if (Array.isArray(categories)) { for (const category of categories) { if (typeof category === "string") { - if (category.length < 1) { + if (category.length < QUOTE_LIMITS.MinimumCategoryLength) { errors.push({ - expected: "string.length <= 1", - message: "Expected each category to be at least 1 character", + expected: `string.length <= ${QUOTE_LIMITS.MinimumCategoryLength}`, + message: `Expected each category to be at least ${QUOTE_LIMITS.MinimumCategoryLength} character`, received: `${category.length}`, }) } - if (category.length > 20) { + if (category.length > QUOTE_LIMITS.MaximumCategoryLength) { errors.push({ - expected: "string.length <= 20", - message: "Expected each category to be less than 20 characters", + expected: `string.length <= ${QUOTE_LIMITS.MaximumCategoryLength}`, + message: `Expected each category to be less than ${QUOTE_LIMITS.MaximumCategoryLength} characters`, received: `${category.length}`, }) } @@ -104,18 +105,18 @@ export function validateQuote(quote: unknown) { } if (typeof submitter === "string") { - if (submitter.length < 1) { + if (submitter.length < QUOTE_LIMITS.MinimumSubmitterLength) { errors.push({ - expected: "string.length <= 1", - message: "Expected the submitter to be at least 1 character", + expected: `string.length <= ${QUOTE_LIMITS.MinimumSubmitterLength}`, + message: `Expected the submitter to be at least ${QUOTE_LIMITS.MinimumSubmitterLength} character`, received: `${submitter.length}`, }) } - if (submitter.length > 20) { + if (submitter.length > QUOTE_LIMITS.MaximumSubmitterLength) { errors.push({ - expected: "string.length <= 20", - message: "Expected the submitter to be less than 20 characters", + expected: `string.length <= ${QUOTE_LIMITS.MaximumSubmitterLength}`, + message: `Expected the submitter to be less than ${QUOTE_LIMITS.MaximumSubmitterLength} characters`, received: `${submitter.length}`, }) } @@ -128,18 +129,18 @@ export function validateQuote(quote: unknown) { } if (typeof text === "string") { - if (text.length < 1) { + if (text.length < QUOTE_LIMITS.MinimumTextLength) { errors.push({ - expected: "string.length <= 1", - message: "Expected the text to be at least 1 character", + expected: `string.length <= ${QUOTE_LIMITS.MinimumTextLength}`, + message: `Expected the text to be at least ${QUOTE_LIMITS.MinimumTextLength} character`, received: `${text.length}`, }) } - if (text.length > 200) { + if (text.length > QUOTE_LIMITS.MaximumTextLength) { errors.push({ - expected: "string.length <= 200", - message: "Expected the text to be less than 200 characters", + expected: `string.length <= ${QUOTE_LIMITS.MaximumTextLength}`, + message: `Expected the text to be less than ${QUOTE_LIMITS.MaximumTextLength} characters`, received: `${text.length}`, }) }