@adobe/spacecat-shared-utils
TypeScript icon, indicating that this package has built-in type declarations

1.14.6 • Public • Published

SpaceCat Shared Utilities

This repository contains a collection of shared utility functions used across various SpaceCat projects. These utilities provide a range of checks and validations, from basic data type validation to more complex checks like ISO date strings and URL validation.

Installation

To install the SpaceCat Shared Utilities, you can use npm:

npm install spacecat-shared-utils

Or, if you are using yarn:

yarn add spacecat-shared-utils

Usage

Here's how you can use the different utility functions in your project:

import { isBoolean, isValidUrl } from 'spacecat-shared-utils';

console.log(isBoolean('true')); // true
console.log(isValidUrl('https://www.example.com')); // true

Functions

The library includes the following utility functions:

  • isBoolean(value): Determines if the given value is a boolean or a string representation of a boolean.
  • isInteger(value): Checks if the given value is an integer.
  • isValidDate(obj): Checks whether the given object is a valid JavaScript Date.
  • isIsoDate(str): Validates whether the given string is a JavaScript ISO date string in Zulu (UTC) timezone.
  • isIsoTimeOffsetsDate(str): Validates whether the given string is a JavaScript ISO date string following UTC time offsets format.
  • isNumber(value): Determines if the given value is a number.
  • isObject(obj): Checks if the given parameter is an object and not an array or null.
  • isString(str): Determines if the given parameter is a string.
  • toBoolean(value): Converts a given value to a boolean. Throws an error if the value is not a boolean.
  • arrayEquals(a, b): Compares two arrays for equality.
  • isValidUrl(urlString): Validates whether the given string is a valid URL with http or https protocol.
  • hasText(str): Checks if the given string is not empty.
  • dateAfterDays(number): Calculates the date after a specified number of days from the current date.

SQS Event Adapter

The library also includes an SQS event adapter to convert an SQS record into a function parameter. This is useful when working with AWS Lambda functions that are triggered by an SQS event. Usage:

import { sqsEventAdapter } from '@adobe/spacecat-shared-utils';

// ...

export const main = wrap(run)
  .with(dataAccess)
  .with(sqsEventAdapter) // Add this line
  .with(sqs)
  .with(secrets)
  .with(helixStatus);

Testing

This library includes a comprehensive test suite to ensure the reliability of the utility functions. To run the tests, use the following command:

npm test

License

This project is licensed under the Apache License 2.0 - see the LICENSE file for details.

Readme

Keywords

none

Package Sidebar

Install

npm i @adobe/spacecat-shared-utils

Weekly Downloads

1,455

Version

1.14.6

License

Apache-2.0

Unpacked Size

62.3 kB

Total Files

13

Last publish

Collaborators

  • dylandepass
  • djaeggi
  • adobehalls
  • fullcolorcoder
  • marbec
  • tripod
  • garthdb
  • lazd
  • adobe-admin
  • patrickfulton
  • trieloff
  • shazron
  • krisnye
  • dcpfsdk
  • natebaldwin
  • devongovett
  • aspro83
  • symanovi
  • dpfister
  • stefan-guggisberg
  • korra
  • rofe
  • kptdobe