2.12.0 • Published 2 years ago

@bgcbrasil/shared v2.12.0

Weekly downloads
-
License
ISC
Repository
bitbucket
Last release
2 years ago

bgc-shared

Common utilities used in multiple BGC projects.

Table of contents


Install

$ npm install @bgcbrasil/shared

Usage

generateAuthResponse

Parses policy parameters

import { CustomError } from '@bgcbrasil/shared'

generateAuthResponse({
	principalId: 'client:cognitoId:clientId',
	effect: 'Allow',
	methodArd: 'arn::lambda',
	contextProps = { // optional
		type: 'alex'
	}
})

startStepFunction

Starts a step function with a random name and stringified input

import { startStepFunction } from "@bgcbrasil/shared";
import { StepFunction } from "aws";

const stepFunctionService = new StepFunction();

startStepFunction({
  input: {
    param1: "alex",
  },
  name: "step",
  arn: "arn:123",
  stepFunctionService,
});

websocketResponse

Handles a response for a websocket connection

import { websocketResponse } from '@bgcbrasil/shared'
import { ApiGatewayManagementApi } from 'aws'

const apiGatewayManagementApi = new ApiGatewayManagementApi()

websocketResponse({
	connectionId: '123' // optional, it will exit gracefully it not provided,
	action: 'mywebsocketaction',
	data: {
		param1: 'alex'
	}
	apiGatewayManagementApi,
})

CustomError

Returns a custom error

CustomError class expects 3 params: message, status and name

import { CustomError } from "@bgcbrasil/shared";

const err = new CustomError("message", 400, "TestError");

throw err;

DateHelper


DateHelper.now()

Returns the current date in ISO8601 format and 'America/Sao_Paulo' timezone

import { DateHelper } from "@bgcbrasil/shared";

const date = DateHelper.now();

console.log(date); // 2021-04-26T11:44:22-03:00

DateHelper.toIsoFormat(date)

Returns the payload date in ISO8601 format and 'America/Sao_Paulo' timezone

date is a javascript date

import { DateHelper } from "@bgcbrasil/shared";

const date = 1619627754231; // a javascript date

const dateFormated = DateHelper.toIsoFormat(date);

console.log(dateFormated); // 2000-01-01T11:44:22-03:00

DateHelper.toZonedTime(date)

Changes date to 'America/Sao_Paulo' timezone

import { DateHelper } from "@bgcbrasil/shared";

const toZonedTime = DateHelper.toZonedTime(new Date());

DateHelper.isValid(date)

Verify if date is a valid date

import { DateHelper } from "@bgcbrasil/shared";

DateHelper.isValid("12/12/2021", "dd/MM/yyyy");

DateHelper.format(date)

Changes date format

import { DateHelper } from "@bgcbrasil/shared";

const formated = DateHelper.format("12/12/2020", "dd/MM/yyyy", "dd-MM-yyyy");

DateHelper.toDate(date, format)

Receives a string and transforms in a date instance

import { DateHelper } from "@bgcbrasil/shared";

const formated = DateHelper.toDate("12/12/2020", "dd/MM/yyyy");

DateHelper.isAfter(date, dateToCompare)

Returns if the first date is after the second one

import { DateHelper } from "@bgcbrasil/shared";

const now = new Date();
const after = addHours(now, 1);

const isAfter = DateHelper.isAfter(now, after); // false

DateHelper.subtract(date, duration)

Subtract the specified years, months, weeks, days, hours, minutes and seconds from the given date

import { DateHelper } from "@bgcbrasil/shared";

const now = new Date(); // Wed Oct 27 2021 22:45:44

const sub = DateHelper.subtract(now, {
  hours: 2,
}); // Wed Oct 27 2021 20:45:44

DateHelper.add(date, duration)

Add the specified years, months, weeks, days, hours, minutes and seconds from the given date

import { DateHelper } from "@bgcbrasil/shared";

const now = new Date(); // Wed Oct 27 2021 20:45:44

const add = DateHelper.add(now, {
  hours: 2,
}); // Wed Oct 27 2021 22:45:44

DateHelper.valueOf(date)

Get the milliseconds timestamp of the given date

import { DateHelper } from "@bgcbrasil/shared";

const now = new Date(); // Wed Oct 27 2021 22:45:44

const value = DateHelper.valueOf(now); // 1635385544143

DateHelper.startOfDay(date)

Return the start of a day for the given date

import { DateHelper } from "@bgcbrasil/shared";

const now = new Date(); // Wed Oct 27 2021 22:45:44

const startOfDay = DateHelper.startOfDay(now); // Wed Oct 27 2021 00:00:00:000

DateHelper.endOfDay(date)

Return the end of a day for the given date

import { DateHelper } from "@bgcbrasil/shared";

const now = new Date(); // Wed Oct 27 2021 22:45:44

const endOfDay = DateHelper.endOfDay(now); // Wed Oct 27 2021 23:59:59:999

DateHelper.diff(dateLeft, dateRight)

Get the number of milliseconds between the given dates

import { DateHelper } from "@bgcbrasil/shared";

const now = new Date(); // 1635385544143 in milliseconds
const after = addMilliseconds(now, 100); // 1635385544243 in milliseconds

const diff = DateHelper.diff(after, now); // 100

EventHelper


EventHelper.parse({ queryStringSkipParseParameters? })

Parse Lambda event body, request context and query string parameters skipping the ones specified

import { EventHelper } from "@bgcbrasil/shared";

const helper = new EventHelper(event);

const parsedEvent = helper.parse({ queryStringSkipParseParameters: ["cpf"] });

EventHelper.validate({ bodySchema?, pathParameters? })

Validates Lambda event body, and path parameters based on options

import { EventHelper } from "@bgcbrasil/shared";

const helper = new EventHelper(event);

const schema = {
  type: "object",
  required: ["a"],
  properties: {
    a: {
      type: "string",
    },
  },
};

helper.validate({ bodySchema: schema, pathParameters: ["searchId"] });

EventHelper.handle({ alwaysValidate? = false, queryStringSkipParseParameters?, bodySchema?, pathParameters? })

Join functionallity of both validate and parse functions. If alwaysValidate is true will validate everyway, else will only validate non API Gateway calls.

import { EventHelper } from "@bgcbrasil/shared";

const helper = new EventHelper(event);

const schema = {
  type: "object",
  required: ["a"],
  properties: {
    a: {
      type: "string",
    },
  },
};

const parsedEvent = helper.handle({
  alwaysValidate: false,
  queryStringSkipParseParameters: ["cpf"],
  bodySchema: schema,
  pathParameters: ["searchId"],
});

ErrorHelper


ErrorHelper.handleError(message, ,infos, ,local)

Returns errors informations

import { ErrorHelper } from "@bgcbrasil/shared";

const helper = new ErrorHelper([
  { name: "SequelizeUniqueConstraintError", status: 409 },
]);

const { message, status } = helper.handleError(err);

Logger


Logger.info(message, ,infos, ,local, ,depth)

Displays informational massages on console

message string message to be displayed

infos object(s) to be displayed (optional)

local if true only shows logs in local environment (defaults to false)

depth number of recursive calls in objects

Logger.info("info", { info }, true, 2);

Logger.error(message, ,infos, ,local, ,depth)

Displays error massages on console

message string message to be displayed

infos object(s) to be displayed (optional)

local if true only shows logs in local environment (defaults to false)

depth number of recursive calls in objects

Logger.error("error", { error });

Logger.warning(message, ,infos, ,local, ,depth)

Displays warning massages on console

message string message to be displayed

infos object(s) to be displayed (optional)

local if true only shows logs in local environment (defaults to false)

depth number of recursive calls in objects

Logger.warning("warning", { info });

StringHelper

String functions

StringHelper.normalize()

import { StringHelper } from "@bgcbrasil/shared";

const string = new StringHelper("áéíóú").normalize();

console.log(string); // aeiou

StringHelper.camelize()

import { StringHelper } from "@bgcbrasil/shared";

const string = new StringHelper("A B C").camelize();

console.log(string); // aBC

StringHelper.pascalize()

import { StringHelper } from "@bgcbrasil/shared";

const string = new StringHelper("12 3 4 5").pascalize();

console.log(string); //  12345

StringHelper.removeMultipleLineBreaks()

import { StringHelper } from "@bgcbrasil/shared";

const string = new StringHelper(`
A B
C D
`).removeMultipleLineBreaks();

console.log(string); //  A B C D

StringHelper.compare(b)

import { StringHelper } from "@bgcbrasil/shared";

const { percentageMatch, levenshtein, similarity } = new StringHelper(
  "Ana"
).compare("banana");

Validator

Class to validate params

validator.isCpfValid

Returns if a cpf is valid

import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.isCpfValid("55085456033");

validator.isCnpjValid

Returns if a cnpj is valid

import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.isCnpjValid("55085456033");

validator.isEmailValid

Returns if a email is valid

import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.isEmailValid("pessoa@gmail.com.br");

validator.isNameValid

Returns if a name is valid

import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.isNameValid("alex dos santos fulano da silva");

validator.isURLValid

Returns if a url is valid

import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.isURLValid("https://google.com.br");

validator.isPhoneValid

Returns if a phone number is valid

import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.isPhoneValid("21999998888");

validator.matchSchema

Returns if an object is valid given a JSON Schema object

params:

  • object
  • schema
import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.matchSchema(
  {
    productId: "1",
    productName: "chocolate quente",
    number: 1,
    phone: "(800)12345667",
  },
  schema
);

validator.objectHasKeys

Returns if an object contains all keys

import { Validator } from "@bgcbrasil/shared";

const validator = new Validator();

validator.objectHasKeys({ a: "testing", b: 2 }, ["a", "b"], "pathParameters");

dynamooseQuery

Creates and executes a query based on params end model

import { dynamooseQuery } from "@bgcbrasil/shared";
import * as dynamoose from "dynamoose";

const schema = new dynamoose.Schema(
  {
    id: {
      type: String,
    },
    ownerPrincipalGroup: {
      type: String,
      required: true,
      index: {
        name: "ownerPrincipalGroupIndex",
        global: true,
      },
    },
  },
  {
    timestamps: false,
  }
);

const model = dynamoose.model(process.env.dynamodbTable, schema, {
  create: false,
  waitForActive: false,
});

dynamooseQuery({
  params: {
    ownerPrincipalGroup: "client:4",
  },
  model,
});

checkPermissions

Checks if users has permission to acess a resource

import { checkPermissions } from "@bgcbrasil/shared";

checkPermissions({
  ownerPrincipalGroup: "client:4",
  principalGroup: "client:4",
  organizationGroups: [], // opcional
});

getOwnerPrincipalGroup

Retunrs user most important group, useful for create searches

import { getOwnerPrincipalGroup } from "@bgcbrasil/shared";

getOwnerPrincipalGroup({
  ownerPrincipalGroup: "client:4",
  principalGroup: "client:4",
  organizationGroups: [], // opcional
});

getPrincipalGroup

Returns user group(s), useful for consults

import { getPrincipalGroup } from "@bgcbrasil/shared";

getPrincipalGroup({
  ownerPrincipalGroup: "client:4",
  principalGroup: "client:4",
  organizationGroups: [], // opcional
});

Api Response


apiResponse(statusCode, , params)

Provides a response object for api's

statusCode the status code of the request

params

  • header (custom response header)

  • body (custom response body)

apiResponse(statusCode, { body: { message: "Hi!" } });

Handler


Lambda handler responsible for dealing with errors and event parsing / validation

import { handler } from '@bgcbrasil/shared'

const main = handler(lambda);

const schema = {
	type: 'object',
	required: ['a'],
	properties: {
		a: {
			type: 'string'
		},
	}
};

const options = {
	errorHelper = new ErrorHelper(),
	successCallback = async () => { return; },
	errorCallback = async () => { return; },
	alwaysValidate: true,
	bodySchema: schema,
	pathParameters: ['searchId'],
	queryStringSkipParseParameters: ['limit'],
};

const response = await main(event, options);

NotifyDiscord


Used to create notifications on discord, sending cloudWatch log url if (requestId and functionName) passed

import { notifyDiscord } from "@bgcbrasil/shared";

async function main(event, context) {
  const params = {
    content: {
      title: "I Hate Alex",
      description: "He is so annoying",
      color: 16711680,
      fields: [{ name: "I am just kidding", value: "He is kinda nice" }],
    },
    url: "https://discord.com/api/webhooks/842732702344282122/ajN1so4swQ7z_76wfYsLNq87VBWzJ3OzKkRV2D-8b4daV6Mf87vWJQrCof9hlet9j9Pq",
    requestId: context.awsRequestId,
    functionName, // same name defined in the sls function
  };

  notifyDiscord(params);
}

parseEvent


Returns a parsed event

import { parseEvent } from "@bgcbrasil/shared";

const event = {
  body: { a: "test body" },
  queryStringParameters: { a: "test string parameters" },
  pathParameters: { a: "test path parameters" },
  requestContext: { a: "test request context" },
};

const result = await parseEvent(event);

validateEvent


Validates an event based on options

import { validateEvent } from "@bgcbrasil/shared";

const event = {
  body: { a: "test body" },
  pathParameters: { a: "test path parameters" },
};

const schema = {
  type: "object",
  required: ["a"],
  properties: {
    a: {
      type: "string",
    },
  },
};

await validateEvent(event, { bodySchema: Schema, pathParameters: ["b"] });

Request


import { request } from "@bgcbrasil/shared";

const result = await request({
  method: "GET",
  url: "https://url.com.br",
  data: {
    a: "test",
  },
  headers: {
    b: "test",
  },
});

Sleep


sleep(miliseconds)

Provides an asyncronous timed sleep

miliseconds the period that the execution will be sleeping

import { sleep } from "@bgcbrasil/shared";

// waits for 100 ms then logs "olá"
await sleep(100);
console.log("olá!");

divideArrayInBatches


Receives an array and divides it in smallers arrays with same length

import { divideArrayInBatches } from "@bgcbrasil/shared";

const formated = divideArrayInBatches([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 2);
/*
[
  [1, 2],
  [3, 4],
  [5, 6],
  [7, 8],
  [9, 10],
]
*/

findMatchedNames


Receives an array of names and a name, and returns the names inside the array that matches the name given

import { findMatchedNames } from "@bgcbrasil/shared";

const response = findMatchedNames(["Gustavo", "Lucas"], "Gustavo");
/*
[
  "Gustavo"
]
*/

Issue Reporting

If you have found a bug or if you have a feature request, please report them at this repository issues section or directly to the responsible team.

2.12.0-beta.1

2 years ago

2.11.0

2 years ago

2.11.1

2 years ago

2.10.1-beta.1

2 years ago

2.10.0-dev.1

2 years ago

2.10.0-dev.2

2 years ago

2.11.2

2 years ago

2.11.3

2 years ago

2.10.1

2 years ago

2.12.0

2 years ago

2.10.0

2 years ago

2.11.3-beta.1

2 years ago

2.11.0-dev.1

2 years ago

2.11.2-beta.1

2 years ago

2.11.1-beta.1

2 years ago

2.11.0-beta.1

2 years ago

2.9.0-dev.2

3 years ago

2.9.0-dev.1

3 years ago

2.8.0-beta.1

3 years ago

2.8.0

3 years ago

2.9.0-beta.1

3 years ago

2.8.0-dev.2

3 years ago

2.8.0-dev.1

3 years ago

2.9.0

3 years ago

2.5.1-beta.1

3 years ago

2.4.0

3 years ago

2.6.0

3 years ago

2.7.0-dev.1

3 years ago

2.5.0-dev.2

3 years ago

2.5.0-dev.1

3 years ago

2.5.0-beta.1

3 years ago

2.5.2-beta.1

3 years ago

2.6.0-dev.1

3 years ago

2.5.0

3 years ago

2.7.0

3 years ago

2.5.2

3 years ago

2.5.1

3 years ago

2.5.3

3 years ago

2.6.0-beta.1

3 years ago

2.6.0-dev.3

3 years ago

2.6.0-dev.2

3 years ago

2.4.0-beta.1

3 years ago

2.7.0-beta.1

3 years ago

2.3.2-beta.1

3 years ago

2.3.2

3 years ago

2.4.0-dev.1

3 years ago

2.3.2-dev.1

3 years ago

2.3.1

3 years ago

2.3.1-dev.1

3 years ago

2.3.0

3 years ago

2.3.0-beta.1

3 years ago

2.3.0-dev.2

3 years ago

2.3.0-dev.1

3 years ago

2.2.1

3 years ago

2.2.1-beta.1

3 years ago

2.2.1-dev.1

3 years ago

2.2.0

3 years ago

2.2.0-beta.2

3 years ago

2.2.0-beta.1

3 years ago

2.2.0-dev.2

3 years ago

2.2.0-dev.1

3 years ago

2.1.0

3 years ago

2.1.0-beta.1

3 years ago

2.1.0-dev.3

3 years ago

2.1.0-dev.2

3 years ago

2.1.0-dev.1

3 years ago

2.0.0

3 years ago

2.0.0-dev.3

3 years ago

2.0.0-dev.2

3 years ago

1.0.1-beta.1

3 years ago

2.0.0-dev.1

3 years ago

1.1.0-dev.3

3 years ago

1.1.0-dev.2

3 years ago

1.1.0-dev.1

3 years ago

1.0.0

3 years ago

1.0.0-dev.2

3 years ago

1.0.0-dev.1

3 years ago