1. /**
  2. * Cleans JSON data for validation.
  3. *
  4. * @param {object} data - The JSON data to clean.
  5. * @param {object} [config={}] - Optional configuration object.
  6. * @param {string[]} [config.requiredFields=[]] - Array of required fields.
  7. * @param {function} [config.validatorFunctions={}] - Object containing validator functions (e.g., email, number).
  8. * @returns {object|null} - The cleaned data, or null if validation fails.
  9. */
  10. function cleanData(data, config = {}) {
  11. if (typeof data !== 'object' || data === null) {
  12. console.warn("Data is not a valid object. Returning null.");
  13. return null;
  14. }
  15. const cleanedData = {};
  16. for (const key in data) {
  17. if (data.hasOwnProperty(key)) {
  18. const value = data[key];
  19. // Handle nested objects
  20. if (typeof value === 'object' && value !== null) {
  21. const nestedCleaned = cleanData(value, config);
  22. if (nestedCleaned === null) {
  23. return null; // Propagate validation failure
  24. }
  25. cleanedData[key] = nestedCleaned;
  26. continue;
  27. }
  28. // Handle required fields
  29. if (config.requiredFields && config.requiredFields.includes(key) && value === undefined) {
  30. console.warn(`Missing required field: ${key}. Returning null.`);
  31. return null;
  32. }
  33. //Handle validators
  34. if (config.validatorFunctions && config.validatorFunctions[key]) {
  35. const validator = config.validatorFunctions[key];
  36. const validatedValue = validator(value);
  37. if (validatedValue === false) {
  38. console.warn(`Validation failed for field: ${key}. Returning null.`);
  39. return null;
  40. }
  41. cleanedData[key] = validatedValue;
  42. continue;
  43. }
  44. cleanedData[key] = value;
  45. }
  46. }
  47. return cleanedData;
  48. }

Add your comment