piper-utils 1.1.21 → 1.1.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/bin/main.js CHANGED
@@ -287,7 +287,7 @@ Array.isArray(body.errors)&&(dynamooseError+=body.errors.reduce((acc,err)=>acc+"
287
287
  body.message&&(dynamooseError+=" "+body.message);// If there is any additional detail provided, append it.
288
288
  body.detail&&(dynamooseError+=" "+body.detail);// Trim the message to remove extra spaces.
289
289
  return errorBody.message=dynamooseError.trim(),errorBody}
290
- /***/;var _lodash2=function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}(__webpack_require__(825)),_errorCodes=__webpack_require__(953);function buildResponse(statusCode,body){return{statusCode,headers:{"Access-Control-Allow-Origin":"*","Access-Control-Allow-Credentials":!0},body:JSON.stringify(body)}}function detectSequelizeError(body){const errorBody={};let sequelizeError=_lodash2.default.get(body,"errors",[]).reduce((acc,err)=>acc=acc+" "+_lodash2.default.get(err,"message"),"");const parentError=_lodash2.default.get(body,"parent","");return sequelizeError=sequelizeError+_lodash2.default.get(body,"original.detail","")+_lodash2.default.get(body,"TypeError","")+parentError,errorBody.message=sequelizeError.trim(),errorBody}function detectJoyError(body){const errorBody={},joyError=_lodash2.default.get(body,"details[0]",{}),v=(_lodash2.default.get(body,"details[0].context.details")||[]).reduce((acc,contextItem)=>acc=acc+" "+contextItem?.message||"","");return console.error("USER VALIDATION ERROR:",body),(joyError?.message||""+v)&&(errorBody.message=_lodash2.default.trim(joyError?.message||""+v)),errorBody.statusCode=400,errorBody.errorCode="4000",errorBody}},
290
+ /***/;var _lodash2=function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}(__webpack_require__(825)),_errorCodes=__webpack_require__(953);function buildResponse(statusCode,body){return{statusCode,headers:{"Access-Control-Allow-Origin":"*","Access-Control-Allow-Credentials":!0},body:JSON.stringify(body)}}function detectSequelizeError(body){const errorBody={};let sequelizeError=_lodash2.default.get(body,"errors",[]).reduce((acc,err)=>acc=acc+" "+_lodash2.default.get(err,"message"),"");const parentError=_lodash2.default.get(body,"parent","");return sequelizeError=sequelizeError+_lodash2.default.get(body,"original.detail","")+_lodash2.default.get(body,"TypeError","")+parentError,errorBody.message=sequelizeError.trim(),errorBody}function detectJoyError(body){const errorBody={},joyError=_lodash2.default.get(body,"details[0]",{}),v=(_lodash2.default.get(body,"details[0].context.details")||[]).reduce((acc,contextItem)=>acc=acc+" "+contextItem?.message||"","");console.error("USER VALIDATION ERROR:",body);const msg=(joyError?.message||"")+v;return msg&&(errorBody.message=_lodash2.default.trim(msg)),errorBody.statusCode=400,errorBody.errorCode="4000",errorBody}},
291
291
  /***/908:
292
292
  /***/(__unused_webpack_module,exports,__webpack_require__)=>{Object.defineProperty(exports,"__esModule",{value:!0}),exports.s3Utils=s3Utils;var _clientS=__webpack_require__(43);function s3Utils(action,params){return(new _clientS.S3)[action](params)}const S3Util={getObject:params=>async function getS3(params){const s3=new _clientS.S3,response=await s3.getObject(params);return response?.Body.transformToString("utf-8")}
293
293
  /***/(params),deleteObject:params=>s3Utils("deleteObject",params),putObject:params=>s3Utils("putObject",params),listObjectsV2:params=>s3Utils("listObjectsV2",params)};exports.default=S3Util},
package/bin/main.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"main.js","mappings":"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","sources":["webpack://piper-utils/./src/database/dbSetup/migrations.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/accessRightsUtils.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/createFilters.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/createIncludes.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/createSort.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/defaultFilters.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/findAll.js","webpack://piper-utils/./src/dynamo/dynamoUtils.js","webpack://piper-utils/./src/eventManager/handleEvents.js","webpack://piper-utils/./src/eventManager/handleFile.js","webpack://piper-utils/./src/eventManager/publishEvents.js","webpack://piper-utils/./src/eventManager/watchBucket.js","webpack://piper-utils/./src/requestResponse/errorCodes.js","webpack://piper-utils/./src/requestResponse/requestResponse.js","webpack://piper-utils/./src/s3/S3Utils/S3Utils.js","webpack://piper-utils/./src/sns/SNSUtils.js","webpack://piper-utils/external commonjs \"@aws-sdk/client-dynamodb\"","webpack://piper-utils/external commonjs \"@aws-sdk/client-s3\"","webpack://piper-utils/external commonjs \"@aws-sdk/client-sns\"","webpack://piper-utils/external commonjs \"@aws-sdk/lib-dynamodb\"","webpack://piper-utils/external commonjs \"bluebird\"","webpack://piper-utils/external commonjs \"dayjs\"","webpack://piper-utils/external commonjs \"dayjs/plugin/customParseFormat\"","webpack://piper-utils/external commonjs \"dayjs/plugin/isSameOrBefore\"","webpack://piper-utils/external commonjs \"dayjs/plugin/utc.js\"","webpack://piper-utils/external commonjs \"lodash\"","webpack://piper-utils/external commonjs \"sequelize\"","webpack://piper-utils/external commonjs \"umzug\"","webpack://piper-utils/webpack/bootstrap","webpack://piper-utils/./src/index.js"],"sourcesContent":["import _ from 'lodash';\nimport { SequelizeStorage, Umzug } from 'umzug';\n\n/**\n * Execute database migrations\n * @param {string} databaseName - name of database to create (or verify existence)\n * @param {object} sequelizeInstance - instance of Sequelize (must be initialized)\n * @param {function} initializeModels - function to run to sync Sequelize models with database\n * @param {string} pathToMigrationFolder - pass in the path if using windows. windows and linux PWD will be different\n */\nexport async function runMigrations(databaseName,\n sequelizeInstance,\n initializeModels,\n pathToMigrationFolder = `${process.env.PWD}/migrations/*.js`) {\n const umzug = new Umzug({\n migrations: { glob: pathToMigrationFolder },\n context: sequelizeInstance.getQueryInterface(),\n storage: new SequelizeStorage({ sequelize: sequelizeInstance }),\n logger: console\n });\n\n const pendingMigrations = await umzug.pending();\n console.log('------->UTIL Pending Migrations:', pendingMigrations, pathToMigrationFolder);\n await umzug.up().catch((upError) => {\n console.error('Migration Error: ', upError);\n return umzug.down({\n migrations: _.chain(pendingMigrations)\n .map('file')\n .reverse()\n .value()\n }).then(() => {\n const msg = 'UTIL Error: Error with migrating up:' + upError;\n console.error(msg);\n throw new Error(msg);\n }, (downError) => {\n const msg = 'UTIL Error: Error with migrating down:' + downError;\n console.error(msg);\n throw new Error(msg);\n });\n });\n\n // The following line is needed to sync (create) tables, but not to database updates\n // in the past it worked to leave it in, but now the tags module causes foreign key problems\n // The tables are still initiated by being passed in to run migrations\n await initializeModels();\n}","import _, { isEmpty } from 'lodash';\r\nimport { errorList } from '../../../requestResponse/errorCodes.js';\r\nimport { parseBody } from '../../../requestResponse/requestResponse.js';\r\n\r\nexport function isSystemUser(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:SYSTEM') ||\r\n _.get(event, 'requestContext.authorizer.custom:SYSTEM') ||\r\n 'false';\r\n let isSys = false;\r\n try {\r\n isSys = JSON.parse(jsonToParse);\r\n return isSys;\r\n } catch (e) {\r\n console.error('error with system user:', e);\r\n\r\n return false;\r\n }\r\n}\r\n\r\nexport function isSuperUser(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:SUPER') ||\r\n _.get(event, 'requestContext.authorizer.custom:SUPER') ||\r\n 'false';\r\n let isSys = false;\r\n\r\n try {\r\n isSys = JSON.parse(jsonToParse);\r\n\r\n return isSys;\r\n } catch (e) {\r\n\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Throws unauthorized error if the user is not a super user.\r\n * Mirrors the behavior and style of checkModule but focused on SUPER role.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n */\r\nexport function checkIsSuper(event) {\r\n // Super or System users are always allowed\r\n if (isSuperUser(event)) {\r\n return;\r\n }\r\n if (isSystemUser(event)) {\r\n return;\r\n }\r\n\r\n // In local builds allow bypass to ease development and tests\r\n if (process.env.BUILD_ENV === 'local') {\r\n return;\r\n }\r\n\r\n throw errorList.unauthorized;\r\n}\r\n\r\n/**\r\n * Get the allowed businessIds for a user from the lambda event, compare it to businessIds, return what user has access to.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @param {{useCognitoBid:boolean}} [options] - An object with options, useCognitoBid prefers the businessId set in cognito if set and does not return the local bid of 1 if a bid is in the claim.\r\n * @returns {array} A list of businessIds that have been requested and are allowed to for some user.\r\n */\r\nexport function accessRightsUtils(event, options) {\r\n const useCognitoBid = _.get(options, 'useCognitoBid', false);\r\n const requestedBusinessIds = getRequestedBusinessIds(event);\r\n const allowedBusinessIds = getAllowedBusinessIds(event, useCognitoBid);\r\n\r\n if (isSuperUser(event)) {\r\n let v = requestedBusinessIds;\r\n if (_.isEmpty(requestedBusinessIds)) {\r\n v = allowedBusinessIds;\r\n }\r\n\r\n return v;\r\n }\r\n if (isSystemUser(event)) {\r\n return requestedBusinessIds;\r\n }\r\n\r\n if (requestedBusinessIds.length === 0) {\r\n return allowedBusinessIds;\r\n }\r\n\r\n return _.intersection(requestedBusinessIds, allowedBusinessIds);\r\n}\r\n\r\n/**\r\n * Get the businessID set in cognito as custom:DBI.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {string} The businessID set in cognito as custom:DBI\r\n */\r\nexport function userDefaultBid(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:DBI') ||\r\n _.get(event, 'requestContext.authorizer.custom:DBI') ||\r\n '{}';\r\n\r\n const dbi = JSON.parse(jsonToParse);\r\n return _.get(dbi, 'defaultBid', '') || '1';\r\n}\r\n\r\n/**\r\n * Get requested businessIds from the query string.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {array} The businessID requested by the query string\r\n */\r\nexport function getRequestedBusinessIds(event) {\r\n let requestedBusinessIds = _.get(event, 'queryStringParameters.businessIds', null);\r\n const body = parseBody(event);\r\n const bodyBid = body?.businessId;\r\n if (requestedBusinessIds) {\r\n return requestedBusinessIds ? requestedBusinessIds.split(',') : [];\r\n } else if (bodyBid) {\r\n return [ bodyBid ];\r\n } else {\r\n return [];\r\n }\r\n}\r\n\r\n/**\r\n * Get the allowed businessIds for a user from cognito custom:AR property.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @param useCognitoBid\r\n * @returns {array} The businessID requested by the query string\r\n */\r\nfunction getAllowedBusinessIds(event, useCognitoBid) {\r\n const businesses = getBusinessesInfo(event, useCognitoBid);\r\n return Object.keys(businesses);\r\n}\r\n\r\nexport function getAccessRightsInfo(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:AR') ||\r\n _.get(event, 'requestContext.authorizer.custom:AR') ||\r\n '{}';\r\n const accessRights = JSON.parse(jsonToParse);\r\n return _.get(accessRights, 'businessIds', {});\r\n}\r\n\r\nexport function getDefaultBusinessIDInfo(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:DBI') ||\r\n _.get(event, 'requestContext.authorizer.custom:DBI') ||\r\n '{}';\r\n const dbi = JSON.parse(jsonToParse);\r\n\r\n return _.get(dbi, 'defaultBid', {});\r\n}\r\n\r\nexport function getBusinessesInfo(event, useCognitoBid = false) {\r\n const json = _.get(event, 'requestContext.authorizer.claims.custom:AR') ||\r\n _.get(event, 'requestContext.authorizer.custom:AR') ||\r\n '{}';\r\n\r\n let businessIds = _.get(JSON.parse(json), 'businessIds', {});\r\n\r\n // Local environment tweaks\r\n if (process.env.BUILD_ENV === 'local') {\r\n let b;\r\n try {\r\n b = JSON.parse(event?.body);\r\n } catch (e) {\r\n }\r\n const bodyBid = b?.businessId;\r\n // Always inject the default local BID “1” unless the caller explicitly wants\r\n // what Cognito says **and** Cognito actually returned something.\r\n if (!useCognitoBid) {\r\n businessIds = { ...businessIds, '1': 'A' };\r\n }\r\n\r\n // If Cognito gave no BIDs at all, fall back to the local default.\r\n if (isEmpty(businessIds)) {\r\n businessIds = { '1': 'A' };\r\n }\r\n // a businessId is found on the body for local allow it\r\n if (bodyBid) {\r\n businessIds[bodyBid] = 'A';\r\n }\r\n }\r\n\r\n return businessIds;\r\n}\r\n\r\n/**\r\n * Get the modules listed in custom:MOD.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {array} The Module access list\r\n */\r\nexport function getModuleInfo(event) {\r\n let jsonToParse =\r\n _.get(event, 'requestContext.authorizer.claims.custom:MOD') ||\r\n _.get(event, 'requestContext.authorizer.custom:MOD') ||\r\n _.get(event, 'requestContext.authorizer.claims.custom:AR') ||\r\n _.get(event, 'requestContext.authorizer.custom:AR') ||\r\n\r\n '{}';\r\n\r\n const moduleRights = JSON.parse(jsonToParse);\r\n return _.get(moduleRights, 'module', {});\r\n}\r\n\r\n/**\r\n * Get the modules listed in custom:MOD.\r\n *\r\n * @param {string} moduleName - A sting name for a module.\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {array} The Module access list\r\n */\r\nexport function checkModule(moduleName, event) {\r\n const moduleRights = getModuleInfo(event);\r\n let allowAccess = _.get(moduleRights, moduleName, false);\r\n\r\n if (isSuperUser(event)) {\r\n return;\r\n }\r\n if (isSystemUser(event)) {\r\n return;\r\n }\r\n\r\n if (process.env.BUILD_ENV === 'local') {\r\n return;\r\n }\r\n if (!allowAccess) {\r\n throw errorList.unauthorized;\r\n }\r\n}\r\n\r\nexport const userRoles = {\r\n admin: 'A',\r\n read: 'R',\r\n write: 'W'\r\n};\r\n\r\n/**\r\n * @param {{body: string}} event\r\n * @param {{useCognitoBid:boolean}} [options] - An object with options, useCognitoBid prefers the businessId set in cognito if set and does not return the local bid of 1 if a bid is in the claim.\r\n * @returns {string} businessId\r\n */\r\nexport function checkWriteAccess(event, options) {\r\n const eventBody = parseBody(event);\r\n const businessIds = accessRightsUtils(event, options) || [];\r\n const businessId = businessIds.find((id) => id === eventBody.businessId);\r\n const raw = getBusinessesInfo(event);\r\n const userRight = raw[businessId];\r\n\r\n if (isSuperUser(event)) {\r\n return eventBody.businessId;\r\n }\r\n\r\n if (isSystemUser(event)) {\r\n return eventBody.businessId;\r\n }\r\n\r\n if (process.env.BUILD_ENV === 'local') {\r\n return eventBody.businessId;\r\n }\r\n\r\n if ((userRight !== userRoles.admin && userRight !== userRoles.write) || (!userRight)) {\r\n throw errorList.unauthorized;\r\n }\r\n return businessId;\r\n}\r\n\r\n","import _ from 'lodash';\nimport DB from 'sequelize';\nimport dayjs from 'dayjs';\nimport utc from 'dayjs/plugin/utc.js';\nimport { errorList } from '../../../requestResponse/errorCodes.js';\nimport { accessRightsUtils } from './accessRightsUtils.js';\n\ndayjs.extend(utc);\n\n/**\n * Create sequelize where clause from query string parameters and default sort object\n *\n * @param {object} event - the query parameters from the event passed by lambda\n * @param {object} objectFilters - the default filters object created by createDefaultFilters\n * @returns {object} An sequelize where object\n */\nexport const createFilters = function (event, objectFilters) {\n let query = _.get(event, 'queryStringParameters', {}) || {};\n\n //searchString, startDate and endDate are bolted on as a convenience\n //startDate and endDate automatically get applied to createdAt\n //searchString allows you to search for a single string against many fields\n const searchString = _.get(query, 'searchString');\n const startDate = _.get(query, 'startDate');\n const endDate = _.get(query, 'endDate');\n\n const where = Object.keys(query).reduce((acc, item) => {\n const val = _.get(objectFilters, item, null);\n\n if (val) {\n const itemName = item.includes('.')\n ? `$${item}$`\n : item;\n\n acc[itemName] = {};\n if (val.filterType === DB.Op.iLike) {\n acc[itemName][val.filterType] = `%${query[item]}%`;\n } else if (val.filterType === DB.Op.or) {\n acc[itemName][val.filterType] = [-1 * +query[item], +query[item]];\n } else if (val.filterType === DB.Op.in) {\n acc[itemName][val.filterType] = query[item].split(',');\n } else if (val.filterType === DB.Op.in) {\n acc[itemName][val.filterType] = query[item].split(',');\n } else {\n let parsedJson;\n try {\n // value is JSON, parse it\n parsedJson = JSON.parse(query[item]);\n } catch (e) {\n // value is not JSON, pass through as a string\n parsedJson = query[item];\n }\n acc[itemName][val.filterType] = parsedJson;\n }\n\n if (val.type === DB.BOOLEAN) {\n const queryValue = _.get(query, item, '').toLowerCase();\n\n const booleanMap = {\n 'false': false,\n 'null': null,\n 'true': true\n };\n\n acc[itemName][val.filterType] = booleanMap[queryValue];\n }\n }\n\n return acc;\n }, {});\n\n if (objectFilters?.active && !where?.active) {\n where.active = true;\n }\n\n const businessIds = accessRightsUtils(event);\n const filterAdds = {\n businessId: businessIds\n };\n\n if (startDate && endDate) {\n const s = dayjs.utc(startDate);\n const e = dayjs.utc(endDate);\n const dates = {\n [DB.Op.between]: [s.toDate(), e.toDate()]\n };\n if (!s.isValid()) {\n throw { ...errorList.invalidStartDate };\n }\n\n if (!e.isValid()) {\n throw { ...errorList.invalidEndDate };\n }\n\n filterAdds.createdAt = dates;\n }\n\n if (searchString) {\n const adds = Object.keys(objectFilters).reduce((acc, item) => {\n const type = objectFilters[item].filterType;\n const dataType = objectFilters[item].type;\n\n if (type === DB.Op.iLike) {\n const newOr = {};\n const itemName = item.includes('.')\n ? `$${item}$`\n : item;\n newOr[itemName] = {\n [DB.Op.iLike]: `%${query['searchString']}%`\n };\n acc.push(newOr);\n }\n\n if (!_.isNaN(Number(query['searchString'])) && !(dataType instanceof DB.BOOLEAN)) {\n\n if (type === DB.Op.eq) {\n const newOr = {};\n const itemName = item.includes('.') ? `$${item}$` : item;\n newOr[itemName] = {\n [DB.Op.eq]: `${query['searchString']}`\n };\n acc.push(newOr);\n }\n }\n\n return acc;\n }, []);\n\n filterAdds[DB.Op.or] = adds;\n }\n\n const withDate = Object.assign(where, filterAdds);\n\n // Build nested objects for any JSONB fields defined in objectFilters\n Object.keys(objectFilters || {}).forEach((k) => {\n const def = objectFilters[k];\n if (def && def.type === 'jsonb' && def.field) {\n const prefix = `${def.field}.`;\n const nestedRoot = {};\n let found = false;\n\n Object.keys(query).forEach((qKey) => {\n if (qKey.startsWith(prefix)) {\n const path = qKey.substring(prefix.length);\n _.set(nestedRoot, path.split('.'), query[qKey]);\n found = true;\n }\n });\n\n if (found) {\n withDate[def.field] = nestedRoot;\n }\n }\n });\n\n return withDate;\n};\n","import _ from 'lodash';\n\n/**\n * Create sequelize includes array from query string parameters and default sequelize model\n *\n * @param {object} event - the query parameters from the event passed by lambda\n * @param {object} objectFilters - the default filters object created by createDefaultFilters\n * @returns {object} A sequelize includes array\n */\n\nexport function createIncludes(event, objectFilters) {\n const query = _.get(event, 'queryStringParameters', {}) || {};\n\n const keys = Object.keys(objectFilters);\n\n const canBeIncluded = keys.reduce((acc, item) => {\n acc = includeSubItem(item, acc);\n\n return acc;\n }, []);\n\n const askedForInQuery = Object.keys(query).reduce((acc, item) => {\n if (item === 'sort') {\n query[item].split(',').forEach((sortItem) => {\n sortItem = sortItem.indexOf('-') === 0 ? sortItem.substr(1) : sortItem;\n acc = includeSubItem(sortItem, acc);\n });\n }\n\n acc = includeSubItem(item, acc);\n\n return acc;\n }, []);\n\n return _.intersection(canBeIncluded, askedForInQuery);\n}\n\nexport function includeSubItem(queryStringItem, acc = []) {\n const dot = queryStringItem.indexOf('.');\n if (dot > 0) {\n acc.push(queryStringItem.substring(0, dot));\n }\n\n return acc;\n}","import _ from 'lodash';\n\n/**\n * Create sequelize order clause from query string parameters and default sort object\n *\n * @param {object} event - the event created AWS lambda, it will contain queryStringParameters with sort property a comma seperated list of sortable fields * @param {object} objectFilters - the default filters object created by createDefaultFilters\n * @param {object} defaultFilter - A default filter object as built by createDefault Filters, if items are not on the schema they will not be in the order by\n * @returns {object} An sequelize order by object\n */\nexport const createSort = function (event, defaultFilter) {\n let copyOfDefaultFilter = _.clone(defaultFilter);\n let query = _.get(event, 'queryStringParameters', {}) || {};\n let sort = _.get(query, 'sort', '-updatedAt') || '-updatedAt';\n\n return sort.split(',').reduce((acc, item) => {\n\n const testItem = item.indexOf('-') === 0 ? item.substr(1) : item;\n\n if (_.get(copyOfDefaultFilter, testItem, null)) {\n const sortItem = [];\n\n testItem.split('.').forEach((parentChildList) => {\n sortItem.push(parentChildList);\n });\n\n if (item.indexOf('-') === 0) {\n sortItem.push('DESC');\n } else {\n sortItem.push('ASC');\n }\n acc.push(sortItem);\n }\n\n return acc;\n }, []);\n};\n","import _ from 'lodash';\nimport DB from 'sequelize';\n\n/**\n * Create an object with default filters for a given sequeliaze Schema Object, and set of sub schemas\n *\n * @param {object} schema - type is sequelize data type\n * @param {object} subSchemas - An object with alias as the key and sequelize schema as the value http://docs.sequelizejs.com/class/lib/sequelize.js~Sequelize.html#instance-method-define\n * sub schema can be {location: locationSchema} or {location: {as: \"asAlias\", schema: schema}}\n * @returns {object} An Object with a default filter for each dataType CHAR and TEXT will get a $like operator, INTEGER, DECIMAL and BOOLEAN will get a $eq.\n */\nexport function defaultFilters(schema, subSchemas = {}) {\n schema = _.clone(schema);\n\n const filters = {};\n\n addFiltersFromSchema(schema, filters);\n Object.keys(subSchemas).forEach((key) => {\n addFiltersFromSchema(subSchemas[key], filters, key);\n });\n\n return filters;\n}\n\nexport function addFiltersFromSchema(schema, filters, keyPrefix = '') {\n const asLinkAlias = _.get(schema, 'as', null);\n schema = _.get(schema, 'schema') || schema;\n\n return Object.keys(schema).reduce((acc, item) => {\n let key = item;\n\n if (asLinkAlias) {\n acc[asLinkAlias] = { type: DB.STRING, filterType: DB.Op.eq };\n }\n\n if (keyPrefix) {\n key = `${keyPrefix}.${item}`;\n }\n\n if (schema[item].filterType) {\n acc[key] = { filterType: schema[item].filterType };\n\n return acc;\n }\n\n const itemType = schema[item].type;\n\n //new sequelize uses class symbols instead of objects\n if (itemType instanceof DB.STRING) {\n acc[key] = { filterType: DB.Op.iLike };\n } else if (itemType instanceof DB.CHAR) {\n acc[key] = { filterType: DB.Op.iLike };\n } else if (itemType instanceof DB.TEXT) {\n acc[key] = { filterType: DB.Op.iLike };\n } else if (itemType instanceof DB.DECIMAL) {\n acc[key] = { filterType: DB.Op.or };\n } else if (itemType instanceof DB.INTEGER) {\n acc[key] = { filterType: DB.Op.or };\n } else if (itemType instanceof DB.BIGINT) {\n acc[key] = { filterType: DB.Op.or };\n } else if (itemType instanceof DB.BOOLEAN) {\n acc[key] = { type: DB.BOOLEAN, filterType: DB.Op.eq };\n } else if (itemType instanceof DB.JSONB) {\n acc[key] = { type: itemType, filterType: DB.Op.contains };\n } else if (itemType instanceof DB.DATE) {\n acc[key] = { filterType: DB.Op.between };\n } else if (itemType instanceof DB.DATEONLY) {\n acc[key] = { filterType: DB.Op.eq };\n }\n\n //these are automatically part of the models so add them always\n acc['createdAt'] = { type: DB.DATE, filterType: DB.Op.between };\n acc['updatedAt'] = { type: DB.DATE, filterType: DB.Op.between };\n acc['id'] = { type: DB.INTEGER, filterType: DB.Op.eq };\n\n return acc;\n }, filters);\n}\n","/**\n * create pagination object from Sequelize findAll\n * @param {object} result - sequelize result\n * @param {number} limit - max number of results to return\n * @param {number} offset - page offset\n */\nexport function getPaginationFromFindAll(result, limit, offset) {\n result = result || [];\n limit = limit || 0;\n offset = offset || 0;\n\n const hasMore = result.length > limit;\n if (hasMore) {\n result.splice(-1, 1);\n }\n const pageObject = {\n offset: offset,\n limit: limit,\n rows: result,\n hasMore: hasMore\n };\n\n return pageObject;\n}\n\n/**\n * wrapper for Sequelize findAll\n * @param {object} model - instance of Sequelize (must be initialized)\n * @param {*&{include: [{model: *}], where: {businessId: Array}, order: [string[]]}} options - instance of Sequelize (must be initialized)\n */\nexport async function findAll(model, options) {\n\n const limit = options.limit || 0;\n const includes = options.includes || { all: true, nested: true };\n const findArgs = Object.assign({include: includes}, options, { limit: limit + 1 });\n const results = await model.findAll(findArgs);\n return getPaginationFromFindAll(results, limit, options.offset);\n}\n\nconst findUtils = {\n findAll\n};\nexport default findUtils;","import { DynamoDBDocument } from '@aws-sdk/lib-dynamodb';\nimport { DynamoDB } from '@aws-sdk/client-dynamodb';\n\nconst dynamoUtil = {\n get: (params) => get(params)\n};\n\n/**\n * @param {{TableName:string, Key:{key:string}}} params\n */\nasync function get(params) {\n const dynamoDb = DynamoDBDocument.from(new DynamoDB());\n return dynamoDb.get(params);\n}\n\nexport default dynamoUtil;","import { handleFile } from './handleFile.js';\nimport _ from 'lodash';\nimport Promise from 'bluebird';\n\nexport function handleEvents(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders = false, userImportTypes) {\n if (!event || !event.Records) {\n return Promise.resolve();\n }\n\n let hasErrors = false;\n\n return Promise.map(event.Records, (record) => {\n const snsInfo = JSON.parse(_.get(record, 'Sns.Message', '{}'));\n const s3Bucket = snsInfo.bucket;\n const files = snsInfo.files || [];\n\n return Promise.map(files, (file) => {\n let path = decodeURIComponent(file);\n if (path) {\n return handleFile(path, s3Bucket, transformer, { shouldSkipFailedFolders, userImportTypes }).catch((err) => {\n if (errorHandlerPerFile && !errorHandlerPerFile(err, path)) {\n console.error('HANDLE-FILE-CATCH: ', err);\n hasErrors = true;\n }\n });\n }\n });\n }).then(() => {\n if (hasErrors) {\n throw new Error('ERROR: HANDLE-FILE');\n }\n });\n}\n\nexport function handleDirectS3WriteEvent(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders = false, userImportTypes) {\n if (!event || !event.Records) {\n return Promise.resolve();\n }\n\n let hasErrors = false;\n\n return Promise.map(event.Records, (record) => {\n const s3Bucket = record.s3.bucket.name;\n const file = record.s3.object.key || [];\n\n let path = decodeURIComponent(file);\n if (path) {\n return handleFile(path, s3Bucket, transformer, { shouldSkipFailedFolders, userImportTypes }).catch((err) => {\n if (errorHandlerPerFile && !errorHandlerPerFile(err, path)) {\n console.error('HANDLE-FILE-CATCH:', err);\n hasErrors = true;\n }\n });\n }\n\n }).then(() => {\n if (hasErrors) {\n throw new Error('ERROR: HANDLE-FILE (DIRECT S3 EVENT)');\n }\n });\n}\n","import _ from 'lodash';\nimport S3Util from '../s3/S3Utils/S3Utils.js';\n\nexport async function handleFile(path, s3Bucket, transformer, options) {\n const shouldSkipFailedFolders = _.get(options, 'shouldSkipFailedFolders');\n const userImportTypes = _.get(options, 'userImportTypes');\n const params = {\n Bucket: s3Bucket,\n Key: path\n };\n let body;\n\n try {\n body = await S3Util.getObject(params);\n } catch (e) {\n console.error('no such file e.Code', e);\n if (e.Code === 'NoSuchKey' || e.code === 'NoSuchKey') {\n return;\n }\n throw e;\n }\n\n try {\n // exit early for null/undefined or blank string bodies\n if (_.isNil(body) || (_.isString(body) && _.isEmpty(body.trim()))) {\n await S3Util.deleteObject(params);\n return;\n }\n\n const parsedBody = JSON.parse(body);\n\n // exit early for objects like {} or []\n if (_.isEmpty(parsedBody)) {\n await S3Util.deleteObject(params);\n return;\n }\n\n const returnedValue = await transformer(parsedBody);\n await S3Util.deleteObject(params);\n\n return returnedValue;\n } catch (error) {\n console.error('HANDLE-FILE-ERROR', error);\n\n if (!body) {\n return;\n }\n\n let newPath = '';\n\n if (userImportTypes) {\n console.log('USER IMPORT');\n // look for items in the userImportTypes\n const usersImports = Object.values(userImportTypes);\n const items = path.split('/');\n const fileName = _.last(items);\n const folderName = _.first(items);\n\n if (usersImports.indexOf(folderName) > -1) {\n if (shouldSkipFailedFolders) {\n newPath = `${folderName}/error/${fileName}`;\n } else if (_.startsWith(path, `${folderName}/failed-once/`)) {\n newPath = _.replace(path, `${folderName}/failed-once/`, `${folderName}/failed-twice/`);\n } else if (_.startsWith(path, `${folderName}/failed-twice/`)) {\n newPath = _.replace(path, `${folderName}/failed-twice/`, `${folderName}/error/`);\n } else {\n newPath = `${folderName}/failed-once/${fileName}`;\n }\n } else {\n newPath = `pathAndEventMisMatchError/${path}`;\n }\n\n } else {\n if (shouldSkipFailedFolders) {\n newPath = `error/${path}`;\n } else if (_.startsWith(path, 'failed-once/')) {\n newPath = _.replace(path, 'failed-once/', 'failed-twice/');\n } else if (_.startsWith(path, 'failed-twice/')) {\n newPath = _.replace(path, 'failed-twice/', 'error/');\n } else {\n if (_.includes(path, 'delayUntil/')) {\n path = _.last(path.split('/'));\n }\n\n newPath = `failed-once/${path}`;\n }\n }\n\n const newParams = {\n Bucket: s3Bucket,\n Key: newPath,\n Body: body\n };\n\n if (\n containsError(newPath, 'failed-once') ||\n containsError(newPath, 'failed-twice') ||\n containsError(newPath, 'error')\n ) {\n throw new Error('NESTING ERROR');\n }\n\n await S3Util.putObject(newParams);\n await S3Util.deleteObject(params);\n\n throw error;\n }\n}\n\nexport function containsError(str, val) {\n const firstIndex = str.toLowerCase().indexOf(val);\n if (firstIndex === -1) return false;\n const secondIndex = str.toLowerCase().indexOf(val, firstIndex + 1);\n return secondIndex !== -1;\n}\n","import _ from 'lodash';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore';\nimport Promise from 'bluebird';\nimport S3Utils from '../s3/S3Utils/S3Utils.js';\nimport SNSUtil from '../sns/SNSUtils.js';\nimport dynamoUtil from '../dynamo/dynamoUtils.js';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(isSameOrBefore);\n\n/**\n * @param {string} bucket\n * @param {number} maxKeys\n * @param {Object} userImportTypes\n */\nexport async function loop(bucket, maxKeys, userImportTypes) {\n let bucketResult = {};\n let fileList = [];\n\n const currentTime = dayjs();\n\n do {\n bucketResult = await S3Utils.listObjectsV2({\n Bucket: bucket,\n MaxKeys: maxKeys,\n ContinuationToken: _.get(bucketResult, 'NextContinuationToken')\n });\n\n let newFiles = _.filter(bucketResult.Contents, (file) => {\n if (_.startsWith(_.get(file, 'Key'), 'delayUntil/')) {\n const fileDelayTime = _.get(file, 'Key').split('/')[1];\n return dayjs(fileDelayTime, 'YYYYMMDDHHmm').isSameOrBefore(currentTime);\n }\n if (userImportTypes) {\n // look for items in the userImportTypes\n const usersImports = Object.values(userImportTypes);\n const items = file.Key.split('/');\n const fileName = _.last(items);\n const folderName = _.first(items);\n if (_.isEmpty(fileName)) {\n return false;\n\n } else if (usersImports.indexOf(folderName) === -1) {\n return false;\n }\n\n return !_.startsWith(file.Key, `${folderName}/error`);\n }\n return !_.startsWith(file.Key, 'error');\n });\n\n fileList = _.concat(fileList, newFiles);\n } while (bucketResult.IsTruncated && bucketResult.NextContinuationToken && fileList.length < maxKeys);\n\n return fileList;\n}\n\n/**\n * Published SNS events at a steady pace for data in a particular bucket. Should be executed via a cloud watch cron job as a part of a micro service\n *\n * @param {string} configTable - The Dynamo DB table where to get the chunk-size and maxMessage size\n * @param {string} tableKey - The key to the item in the Dynamo DB table that holds the chunk-size and maxMessage size\n * @param {string} bucket - The name of the s3 bucket to watch, when you drop items into this table events will be created\n * @param {string} snsTopic - The name of the snsEvent to publish\n * @param {object} userImportTypes - import types to filter on\n */\nexport async function publishEvents(configTable, tableKey, bucket, snsTopic, userImportTypes) {\n let result;\n try {\n result = await dynamoUtil.get({\n TableName: configTable,\n Key: { key: tableKey }\n });\n } catch (e) {\n console.error(`Cannot get config for key: ${tableKey} table: ${configTable} falling back to defaults of 2 and 10`, e);\n }\n let chunkSize = _.get(result, 'Item.snsChunkSize', 2);\n let maxMessages = _.get(result, 'Item.snsMaxMessages', 10);\n\n const snsCreateTopicResponse = await SNSUtil.createTopic({ Name: snsTopic });\n const topicArn = snsCreateTopicResponse.TopicArn;\n const maxKeys = chunkSize * maxMessages;\n\n const fileList = await loop(bucket, maxKeys, userImportTypes);\n\n const messageList = _.chain(fileList)\n .map('Key')\n .chunk(chunkSize)\n .slice(0, maxMessages)\n .value()\n ;\n\n return Promise.map(messageList, (files) => {\n return SNSUtil.publish({\n Message: JSON.stringify({\n bucket: bucket,\n files: files\n }),\n TopicArn: topicArn\n });\n });\n}","import { publishEvents } from './publishEvents.js';\nimport { handleEvents, handleDirectS3WriteEvent } from './handleEvents.js';\nimport _ from 'lodash';\n\n/**\n * bucket watcher watches a s3 bucket and publishes events to a sns topic, this allows you to process files in s3 with a some transformer function\n * prefix objects with DIRECT to listen to direct s3 events\n *\n * @param {object} params - The parameters for watchBucket, see below\n * @param {object} params.event - The event of the lambda\n * @param {string} params.dynamoConfigTable - The Dynamo DB table where to get the chunkSize and maxMessage size\n * @param {string} params.dynamoConfigKey - The key to the item in the Dynamo DB table that holds the chunkSize and maxMessage size\n * @param {string} params.s3Bucket - The name of the s3 bucket to watch, when you drop items into this table events will be created\n * @param {string} params.snsTopic - The name of the snsEvent to publish\n * @param {function} params.transformer - the function to run on each file\n * @param {function} [params.errorHandlerPerFile] - the function to run on as a catch on each file\n * @param {boolean} [params.shouldSkipFailedFolders] - whether to use the failed-once, failed-twice, error or just error folders\n * @param {object} [params.userImportTypes] - user import subdirectories object map\n */\nexport function watchBucket({\n event,\n dynamoConfigTable,\n dynamoConfigKey,\n s3Bucket,\n snsTopic,\n transformer,\n errorHandlerPerFile = _.noop,\n shouldSkipFailedFolders = false,\n userImportTypes\n }) {\n if (!event || !dynamoConfigTable || !dynamoConfigKey || !s3Bucket || !snsTopic || !transformer) {\n throw new Error('Missing required parameters. Need event, dynamoConfigTable, dynamoConfigKey, s3Bucket, snsTopic, transformer');\n }\n\n const EventSource = _.get(event, 'Records[0].eventSource') || _.get(event, 'Records[0].EventSource');\n\n if (_.isEqual(EventSource, 'aws:sns')) {\n return handleEvents(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders, userImportTypes);\n } else if (_.isEqual(EventSource, 'aws:s3')) {\n const failedOnce = 'failed-once';\n const failedTwice = 'failed-twice';\n const error = 'error';\n const direct = 'DIRECT';\n const key = _.get(event, 'Records[0].s3.object.key') || '';\n const startsWithDirect = _.startsWith(key, direct);\n if (key.includes(failedOnce) || key.includes(failedTwice) || key.includes(error)) {\n // this used to throw, but the throw raised useless alarms, I believed turing throw in to a return was ok\n return;\n }\n\n if (startsWithDirect) {\n console.log('------->DIRECT WRITE FIRE');\n return handleDirectS3WriteEvent(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders, userImportTypes);\n }\n\n } else {\n // the function is being run from the cron job so publish SNS events\n return publishEvents(dynamoConfigTable, dynamoConfigKey, s3Bucket, snsTopic, userImportTypes);\n }\n}\n","export const errorList = {\n invalidInventoryReleaseRequest: {\n message: 'NOT ENOUGH INVENTORY TO FULFILL RELEASE',\n errorCode: '4010',\n statusCode: 400\n },\n alreadyReleased: {\n message: 'ALREADY RELEASED',\n errorCode: '4011',\n statusCode: 400\n },\n alreadyReceived: {\n message: 'RECEIVABLE ALREADY RECEIVED',\n errorCode: '4012',\n statusCode: 400\n },\n invalidItemsRequest: {\n message: 'VALID ITEMS MUST BE INCLUDED',\n errorCode: '4013',\n statusCode: 400\n },\n invalidID: {\n message: 'ID is invalid',\n errorCode: '4014',\n statusCode: 400\n },\n invalidReceivable: {\n message: 'MUST CONTAIN AT LEAST ONE RECEIVABLE',\n errorCode: '4015',\n statusCode: 400\n },\n invalidRequest: {\n message: 'INVALID REQUEST DATA',\n errorCode: '4016',\n statusCode: 400\n },\n invalidAPIKey: {\n message: 'INVALID REQUEST - API MAY KEY INVALID',\n errorCode: '4017',\n statusCode: 400\n },\n qbCreationError: {\n message: 'QUICKBOOKS ERROR - ERROR CREATING OBJECT IN QUICKBOOKS',\n errorCode: '4018',\n statusCode: 400\n },\n cannotReopen: {\n message: 'CANNOT REOPEN - THE ORDER HAS ALREADY BEEN OPENED',\n errorCode: '4018',\n statusCode: 400\n },\n invalidDateFormat: {\n message: 'INVALID DATE FORMAT',\n errorCode: '4019',\n statusCode: 400\n },\n invalidStartDate: {\n message: 'INVALID START DATE',\n errorCode: '4020',\n statusCode: 400\n },\n invalidEndDate: {\n message: 'INVALID END DATE',\n errorCode: '4021',\n statusCode: 400\n },\n invalidOrderStatus: {\n message: 'UNABLE TO EDIT ORDER ITEMS UNLESS THE ORDER IS IN ESTIMATE STATUS',\n errorCode: '4022',\n statusCode: 400\n },\n invalidPaymentStatus: {\n message: 'UNABLE TO UPDATE PAYMENT STATUS PAYMENT MUST BE OPEN',\n errorCode: '4023',\n statusCode: 400\n },\n invalidReleaseStatus: {\n message: 'UNABLE TO UPDATE RELEASE, STATUS RELEASE MUST BE OPEN',\n errorCode: '4024',\n statusCode: 400\n },\n invalidReceivableStatus: {\n message: 'UNABLE TO UPDATE RECEIVABLE, STATUS RECEIVABLE MUST BE OPEN',\n errorCode: '40025',\n statusCode: 400\n },\n invalidJson:{\n message: 'INVALID JSON',\n errorCode: '4005',\n statusCode: 400\n },\n invalidFilter:{\n message: 'INVALID FILTER',\n errorCode: '4026',\n statusCode: 400\n },\n invalidUserNameUpdate:{\n message: 'UNABLE TO UPDATE USERNAME',\n errorCode: '4027',\n statusCode: 400\n },\n imageSizeLimit:{\n message: 'IMAGE SIZE LIMIT 100KB EXCEEDED',\n errorCode: '4028',\n statusCode: 400\n },\n unauthorized:{\n message: 'UNAUTHORIZED',\n errorCode: '4111',\n statusCode: 401\n },\n notFound:{\n message: 'ITEM NOT FOUND',\n errorCode: '4004',\n statusCode: 404\n },\n emailRequired:{\n message: 'NO EMAIL PROVIDED, CHECK CUSTOMER EMAIL',\n errorCode: '4004',\n statusCode: 404\n },\n mobilePhoneRequired:{\n message: 'NO MOBILE PHONE PROVIDED, CHECK CUSTOMER CONTACTS',\n errorCode: '4004',\n statusCode: 404\n },\n invalidCadenceType: {\n message: 'INVALID CADENCE TYPE',\n errorCode: '5001',\n statusCode: 500\n },\n};","import _ from 'lodash';\nimport { errorList } from './errorCodes.js';\n\n/**\n * @param {Object} body\n * @param {{dbClose?:function}} [options]\n */\nexport function success(body, options) {\n const dbClose = _.get(options, 'dbClose', _.noop);\n dbClose();\n\n return buildResponse(200, body);\n}\n\n/**\n * @param {string} html\n * @param {{dbClose:function|undefined}} options\n */\nexport function successHtml(html, options) {\n const dbClose = _.get(options, 'dbClose', _.noop);\n\n dbClose();\n return {\n statusCode: 200,\n headers: {\n 'Content-Type': 'text/html',\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Credentials': true\n },\n body: html\n };\n}\n\n/**\n * @param {string} event\n * @returns string\n */\nexport function getCurrentUserNameFromCognitoEvent(event) {\n const attributes = _.get(event, 'request.userAttributes');\n\n return attributes['cognito:email_alias'] || attributes['email'] || 'UNKNOWN USER';\n}\n\n/**\n * Get the user information from the event object\n *\n * @param event {Object} an event object\n * @returns {{username: string, id: number}}\n */\nexport function getCurrentUser(event) {\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:UID') ||\n _.get(event, 'requestContext.authorizer.custom:UID') ||\n '0';\n\n const id = JSON.parse(jsonToParse);\n\n const username = _.get(event, 'requestContext.authorizer.claims.email') || _.get(event, 'requestContext.authorizer.email') || 'localtestuser@gexample.com';\n\n return {\n username,\n id\n };\n}\n\n/**\n * Create a failure response\n *\n * @param body {Object} an event object\n * @param options {Object} an options object\n * @returns {{statusCode:number, headers:object, body:string}} a response object\n */\nexport function failure(body = {}, options) {\n const dbClose = _.get(options, 'dbClose', _.noop);\n dbClose();\n let cleanedErrorBody;\n\n if (process.env.UTIL_LOG === 'LOG_ALL' || process.env.BUILD_ENV === 'test') {\n console.error('------->UTIL ERROR:', body);\n }\n\n const NORMAL_ERROR = { statusCode: 500, errorCode: '5XX', message: 'INTERNAL UTIL ERROR' };\n cleanedErrorBody = body;\n if (!_.isUndefined(body.details)) {\n cleanedErrorBody = detectJoyError(body);\n } else if (_.isUndefined(body.errorCode) || _.isUndefined(body.statusCode)) {\n cleanedErrorBody = detectSequelizeError(body);\n }\n if (_.get(body, 'response.data.message')) {\n console.error('------->UTIL ERROR: ' + _.get(body, 'response.data.message'));\n }\n console.log('>>>>cleanedErrorBody: ', cleanedErrorBody);\n\n const newBody = _.merge(NORMAL_ERROR, cleanedErrorBody);\n\n return buildResponse(newBody.statusCode, newBody);\n}\n\n/**\n * Create a failure response object\n *\n * @param statusCode {Number} a status code\n * @param body {Object} an event object\n * @returns {{statusCode:number, headers:object, body:string}} a response object\n */\nfunction buildResponse(statusCode, body) {\n return {\n statusCode: statusCode,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Credentials': true\n },\n body: JSON.stringify(body)\n };\n}\n\n/**\n * parse the body of the event object\n *\n * @param requestEvent {{body:string}} an event object\n * @returns event {*} the json object of the body\n */\nexport function parseBody(requestEvent) {\n\n let eventBody = {};\n if (_.isString(requestEvent.body)) {\n try {\n eventBody = JSON.parse(requestEvent.body);\n } catch (e) {\n // Invalid JSON\n eventBody = null;\n\n throw errorList.invalidJson;\n }\n } else if (_.isObject(requestEvent.body)) {\n eventBody = requestEvent.body;\n }\n\n return eventBody;\n}\n\n/**\n * parse the body of the event object\n *\n * @param requestEvent {string|object} an event object\n * @param [callback] {function} undefined a call back function\n * @returns event {*} the json object of the body\n */\nexport function parseEvent(requestEvent, callback) {\n let event = {};\n if (_.isString(requestEvent)) {\n try {\n event = JSON.parse(requestEvent);\n } catch (e) {\n // Invalid JSON\n event = null;\n\n if (callback) {\n callback(Error(e));\n }\n }\n } else if (_.isObject(requestEvent)) {\n event = requestEvent;\n }\n\n return event;\n}\n\n/**\n * parse the body of the event object\n * look for sequelize errors and return a message\n * ERRORS should not be caught here this is a fallback for unknown database errors\n *\n * @param body {object} part of a body response\n * @returns error message object {message:string}\n */\nexport function detectSequelizeError(body) {\n const errorBody = {};\n\n let sequelizeError = _.get(body, 'errors', []).reduce((acc, err) => {\n acc = acc + ' ' + _.get(err, 'message');\n return acc;\n }, '');\n const parentError = _.get(body, 'parent', '');\n\n sequelizeError = sequelizeError + _.get(body, 'original.detail', '') + _.get(body, 'TypeError', '') + parentError;\n errorBody.message = sequelizeError.trim();\n return errorBody;\n}\n\nexport function detectJoyError(body) {\n const errorBody = {};\n const joyError = _.get(body, 'details[0]', {});\n const additionalMessages = _.get(body, 'details[0].context.details') || [];\n\n const v = additionalMessages.reduce((acc, contextItem) => {\n acc = acc + ' ' + contextItem?.message || '';\n return acc;\n }, '');\n\n console.error('USER VALIDATION ERROR:', body);\n if (joyError?.message || '' + v) {\n errorBody.message = _.trim(joyError?.message || '' + v);\n }\n\n errorBody.statusCode = 400;\n errorBody.errorCode = '4000';\n return errorBody;\n}\n\n/**\n * Parse the body of a Dynamoose error response.\n * Attempts to extract a human-readable error message from Dynamoose errors.\n * This is a fallback for unknown database errors.\n *\n * @param {object} body - Part of a body response containing error details.\n * @returns {object} - Error message object { message: string }\n */\nexport function detectDynamooseError(body) {\n const errorBody = {};\n\n // Start with an empty message string.\n let dynamooseError = '';\n\n // If the error body contains an array of errors, concatenate their messages.\n if (Array.isArray(body.errors)) {\n dynamooseError += body.errors.reduce((acc, err) => {\n return acc + ' ' + (err.message || '');\n }, '');\n }\n\n // If there's a top-level message, add it.\n if (body.message) {\n dynamooseError += ' ' + body.message;\n }\n\n // If there is any additional detail provided, append it.\n if (body.detail) {\n dynamooseError += ' ' + body.detail;\n }\n\n // Trim the message to remove extra spaces.\n errorBody.message = dynamooseError.trim();\n\n return errorBody;\n}","import { S3 } from '@aws-sdk/client-s3';\n\nexport function s3Utils(action, params) {\n const s3 = new S3();\n return s3[action](params);\n}\n\nconst S3Util = {\n getObject: (params) => getS3(params),\n deleteObject: (params) => s3Utils('deleteObject', params),\n putObject: (params) => s3Utils('putObject', params),\n listObjectsV2: (params) => s3Utils('listObjectsV2', params)\n};\nexport default S3Util;\n\nasync function getS3(params) {\n const s3 = new S3();\n const response = await s3.getObject(params);\n return response?.Body.transformToString('utf-8');\n}","import { SNS } from '@aws-sdk/client-sns';\n\nconst SNSUtil = {\n publish: (params) => publish(params),\n createTopic: (params) => createTopic(params)\n};\n\nasync function publish(params) {\n const sns = new SNS();\n return await sns.publish(params);\n}\n\nasync function createTopic(params) {\n const sns = new SNS();\n return await sns.createTopic(params);\n}\n\nexport default SNSUtil;\n","module.exports = require(\"@aws-sdk/client-dynamodb\");","module.exports = require(\"@aws-sdk/client-s3\");","module.exports = require(\"@aws-sdk/client-sns\");","module.exports = require(\"@aws-sdk/lib-dynamodb\");","module.exports = require(\"bluebird\");","module.exports = require(\"dayjs\");","module.exports = require(\"dayjs/plugin/customParseFormat\");","module.exports = require(\"dayjs/plugin/isSameOrBefore\");","module.exports = require(\"dayjs/plugin/utc.js\");","module.exports = require(\"lodash\");","module.exports = require(\"sequelize\");","module.exports = require(\"umzug\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","import { handleFile as handleFileImport } from './eventManager/handleFile.js';\nimport { watchBucket as watchBucketImport } from './eventManager/watchBucket.js';\nimport { publishEvents as publishEventsImport } from './eventManager/publishEvents.js';\nimport { createIncludes as createIncludesImport } from './database/dbUtils/queryStringUtils/createIncludes.js';\nimport { createFilters as createFiltersImport } from './database/dbUtils/queryStringUtils/createFilters.js';\nimport { createSort as createSortImport } from './database/dbUtils/queryStringUtils/createSort.js';\nimport { findAll as findAllImport } from './database/dbUtils/queryStringUtils/findAll.js';\nimport { checkModule as checkModuleImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { checkIsSuper as checkIsSuperImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { getModuleInfo as getModuleInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { getAccessRightsInfo as getAccessRightsInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { getDefaultBusinessIDInfo as getDefaultBusinessIDInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { failure as failureImport, success as successImport } from './requestResponse/requestResponse.js';\nimport { runMigrations as runMigrationsImport } from './database/dbSetup/migrations.js';\nimport { getCurrentUser as getCurrentUserImport } from './requestResponse/requestResponse.js';\nimport { successHtml as successHtmlImport } from './requestResponse/requestResponse.js';\nimport { getCurrentUserNameFromCognitoEvent as getCurrentUserNameFromCognitoEventImport } from './requestResponse/requestResponse.js';\nimport { defaultFilters as defaultFiltersImport } from './database/dbUtils/queryStringUtils/defaultFilters.js';\nimport { accessRightsUtils as accessRightsUtilsImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { parseBody as parseBodyImport } from './requestResponse/requestResponse.js';\nimport { parseEvent as parseEventImport } from './requestResponse/requestResponse.js';\nimport { getBusinessesInfo as getBusinessesInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { userDefaultBid as userDefaultBidImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { checkWriteAccess as checkWriteAccessImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { isSystemUser as isSystemUserImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { isSuperUser as isSuperUserImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\n\nexport const handleFile = handleFileImport;\nexport const watchBucket = watchBucketImport;\nexport const publishEvents = publishEventsImport;\nexport const createFilters = createFiltersImport;\nexport const createIncludes = createIncludesImport;\nexport const createSort = createSortImport;\nexport const findAll = findAllImport;\nexport const checkModule = checkModuleImport;\nexport const checkIsSuper = checkIsSuperImport;\nexport const getAccessRightsInfo = getAccessRightsInfoImport;\nexport const getDefaultBusinessIDInfo = getDefaultBusinessIDInfoImport;\nexport const getModuleInfo = getModuleInfoImport;\nexport const failure = failureImport;\nexport const success = successImport;\nexport const runMigrations = runMigrationsImport;\nexport const getCurrentUser = getCurrentUserImport;\nexport const successHtml = successHtmlImport;\nexport const getCurrentUserNameFromCognitoEvent = getCurrentUserNameFromCognitoEventImport;\nexport const defaultFilters = defaultFiltersImport;\nexport const accessRightsUtils = accessRightsUtilsImport;\nexport const parseBody = parseBodyImport;\nexport const parseEvent = parseEventImport;\nexport const getBusinessesInfo = getBusinessesInfoImport;\nexport const userDefaultBid = userDefaultBidImport;\nexport const checkWriteAccess = checkWriteAccessImport;\nexport const isSystemUser = isSystemUserImport;\nexport const isSuperUser = isSuperUserImport;\n"],"names":["async","runMigrations","databaseName","sequelizeInstance","initializeModels","pathToMigrationFolder","process","env","PWD","umzug","Umzug","migrations","glob","context","getQueryInterface","storage","SequelizeStorage","sequelize","logger","console","pendingMigrations","pending","log","up","catch","upError","error","down","_","chain","map","reverse","value","then","msg","Error","downError","_lodash2","_interopRequireDefault","e","__esModule","default","require","_umzug","isSystemUser","exports","isSuperUser","checkIsSuper","event","BUILD_ENV","errorList","unauthorized","accessRightsUtils","userDefaultBid","jsonToParse","get","dbi","JSON","parse","getRequestedBusinessIds","getAccessRightsInfo","accessRights","getDefaultBusinessIDInfo","getBusinessesInfo","getModuleInfo","checkModule","moduleName","moduleRights","allowAccess","checkWriteAccess","options","eventBody","parseBody","businessId","find","id","userRight","userRoles","admin","write","_lodash","_errorCodes","_requestResponse","isSys","useCognitoBid","requestedBusinessIds","allowedBusinessIds","getAllowedBusinessIds","businesses","Object","keys","v","isEmpty","length","intersection","body","bodyBid","split","json","businessIds","b","read","_sequelize2","_dayjs2","_utc2","_accessRightsUtils","dayjs","extend","utc","objectFilters","query","searchString","startDate","endDate","where","reduce","acc","item","val","itemName","includes","filterType","DB","Op","iLike","or","in","parsedJson","type","BOOLEAN","queryValue","toLowerCase","booleanMap","active","filterAdds","s","dates","between","toDate","isValid","invalidStartDate","invalidEndDate","createdAt","adds","dataType","newOr","push","isNaN","Number","eq","withDate","assign","forEach","k","def","field","prefix","nestedRoot","found","qKey","startsWith","path","substring","set","createIncludes","canBeIncluded","includeSubItem","askedForInQuery","sortItem","indexOf","substr","queryStringItem","dot","defaultFilter","copyOfDefaultFilter","clone","testItem","parentChildList","defaultFilters","schema","subSchemas","filters","addFiltersFromSchema","key","keyPrefix","asLinkAlias","STRING","itemType","CHAR","TEXT","DECIMAL","INTEGER","BIGINT","JSONB","contains","DATE","DATEONLY","getPaginationFromFindAll","result","limit","offset","hasMore","splice","rows","findAll","model","all","nested","findArgs","include","findUtils","_libDynamodb","_clientDynamodb","dynamoUtil","params","DynamoDBDocument","from","DynamoDB","handleEvents","transformer","errorHandlerPerFile","shouldSkipFailedFolders","userImportTypes","Records","Promise","resolve","hasErrors","record","snsInfo","s3Bucket","bucket","files","file","decodeURIComponent","handleFile","err","handleDirectS3WriteEvent","s3","name","object","_handleFile","_bluebird2","Bucket","Key","S3Util","getObject","Code","code","isNil","isString","trim","deleteObject","parsedBody","returnedValue","newPath","usersImports","values","items","fileName","last","folderName","first","replace","newParams","Body","containsError","putObject","_S3Utils2","str","firstIndex","loop","publishEvents","configTable","tableKey","snsTopic","TableName","chunkSize","maxMessages","topicArn","SNSUtil","createTopic","Name","TopicArn","maxKeys","fileList","messageList","chunk","slice","publish","Message","stringify","_customParseFormat2","_isSameOrBefore2","_SNSUtils2","_dynamoUtils2","bucketResult","currentTime","S3Utils","listObjectsV2","MaxKeys","ContinuationToken","newFiles","filter","Contents","fileDelayTime","isSameOrBefore","concat","IsTruncated","NextContinuationToken","customParseFormat","watchBucket","noop","dynamoConfigTable","dynamoConfigKey","EventSource","isEqual","failedOnce","failedTwice","direct","startsWithDirect","_publishEvents","_handleEvents","invalidInventoryReleaseRequest","message","errorCode","statusCode","alreadyReleased","alreadyReceived","invalidItemsRequest","invalidID","invalidReceivable","invalidRequest","invalidAPIKey","qbCreationError","cannotReopen","invalidDateFormat","invalidOrderStatus","invalidPaymentStatus","invalidReleaseStatus","invalidReceivableStatus","invalidJson","invalidFilter","invalidUserNameUpdate","imageSizeLimit","notFound","emailRequired","mobilePhoneRequired","invalidCadenceType","success","dbClose","buildResponse","successHtml","html","headers","getCurrentUserNameFromCognitoEvent","attributes","getCurrentUser","username","failure","cleanedErrorBody","UTIL_LOG","isUndefined","details","detectSequelizeError","detectJoyError","newBody","merge","requestEvent","isObject","parseEvent","callback","detectDynamooseError","errorBody","dynamooseError","Array","isArray","errors","detail","sequelizeError","parentError","joyError","contextItem","s3Utils","_clientS","action","S3","getS3","response","transformToString","_clientSns","sns","SNS","module","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","_watchBucket","_createIncludes","_createFilters","_createSort","_findAll","_migrations","_defaultFilters","handleFileImport","watchBucketImport","publishEventsImport","createFiltersImport","createIncludesImport","createSortImport","findAllImport","checkModuleImport","checkIsSuperImport","getAccessRightsInfoImport","getDefaultBusinessIDInfoImport","getModuleInfoImport","failureImport","successImport","runMigrationsImport","getCurrentUserImport","successHtmlImport","getCurrentUserNameFromCognitoEventImport","defaultFiltersImport","accessRightsUtilsImport","parseBodyImport","parseEventImport","getBusinessesInfoImport","userDefaultBidImport","checkWriteAccessImport","isSystemUserImport","isSuperUserImport"],"sourceRoot":""}
1
+ {"version":3,"file":"main.js","mappings":"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","sources":["webpack://piper-utils/./src/database/dbSetup/migrations.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/accessRightsUtils.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/createFilters.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/createIncludes.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/createSort.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/defaultFilters.js","webpack://piper-utils/./src/database/dbUtils/queryStringUtils/findAll.js","webpack://piper-utils/./src/dynamo/dynamoUtils.js","webpack://piper-utils/./src/eventManager/handleEvents.js","webpack://piper-utils/./src/eventManager/handleFile.js","webpack://piper-utils/./src/eventManager/publishEvents.js","webpack://piper-utils/./src/eventManager/watchBucket.js","webpack://piper-utils/./src/requestResponse/errorCodes.js","webpack://piper-utils/./src/requestResponse/requestResponse.js","webpack://piper-utils/./src/s3/S3Utils/S3Utils.js","webpack://piper-utils/./src/sns/SNSUtils.js","webpack://piper-utils/external commonjs \"@aws-sdk/client-dynamodb\"","webpack://piper-utils/external commonjs \"@aws-sdk/client-s3\"","webpack://piper-utils/external commonjs \"@aws-sdk/client-sns\"","webpack://piper-utils/external commonjs \"@aws-sdk/lib-dynamodb\"","webpack://piper-utils/external commonjs \"bluebird\"","webpack://piper-utils/external commonjs \"dayjs\"","webpack://piper-utils/external commonjs \"dayjs/plugin/customParseFormat\"","webpack://piper-utils/external commonjs \"dayjs/plugin/isSameOrBefore\"","webpack://piper-utils/external commonjs \"dayjs/plugin/utc.js\"","webpack://piper-utils/external commonjs \"lodash\"","webpack://piper-utils/external commonjs \"sequelize\"","webpack://piper-utils/external commonjs \"umzug\"","webpack://piper-utils/webpack/bootstrap","webpack://piper-utils/./src/index.js"],"sourcesContent":["import _ from 'lodash';\nimport { SequelizeStorage, Umzug } from 'umzug';\n\n/**\n * Execute database migrations\n * @param {string} databaseName - name of database to create (or verify existence)\n * @param {object} sequelizeInstance - instance of Sequelize (must be initialized)\n * @param {function} initializeModels - function to run to sync Sequelize models with database\n * @param {string} pathToMigrationFolder - pass in the path if using windows. windows and linux PWD will be different\n */\nexport async function runMigrations(databaseName,\n sequelizeInstance,\n initializeModels,\n pathToMigrationFolder = `${process.env.PWD}/migrations/*.js`) {\n const umzug = new Umzug({\n migrations: { glob: pathToMigrationFolder },\n context: sequelizeInstance.getQueryInterface(),\n storage: new SequelizeStorage({ sequelize: sequelizeInstance }),\n logger: console\n });\n\n const pendingMigrations = await umzug.pending();\n console.log('------->UTIL Pending Migrations:', pendingMigrations, pathToMigrationFolder);\n await umzug.up().catch((upError) => {\n console.error('Migration Error: ', upError);\n return umzug.down({\n migrations: _.chain(pendingMigrations)\n .map('file')\n .reverse()\n .value()\n }).then(() => {\n const msg = 'UTIL Error: Error with migrating up:' + upError;\n console.error(msg);\n throw new Error(msg);\n }, (downError) => {\n const msg = 'UTIL Error: Error with migrating down:' + downError;\n console.error(msg);\n throw new Error(msg);\n });\n });\n\n // The following line is needed to sync (create) tables, but not to database updates\n // in the past it worked to leave it in, but now the tags module causes foreign key problems\n // The tables are still initiated by being passed in to run migrations\n await initializeModels();\n}","import _, { isEmpty } from 'lodash';\r\nimport { errorList } from '../../../requestResponse/errorCodes.js';\r\nimport { parseBody } from '../../../requestResponse/requestResponse.js';\r\n\r\nexport function isSystemUser(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:SYSTEM') ||\r\n _.get(event, 'requestContext.authorizer.custom:SYSTEM') ||\r\n 'false';\r\n let isSys = false;\r\n try {\r\n isSys = JSON.parse(jsonToParse);\r\n return isSys;\r\n } catch (e) {\r\n console.error('error with system user:', e);\r\n\r\n return false;\r\n }\r\n}\r\n\r\nexport function isSuperUser(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:SUPER') ||\r\n _.get(event, 'requestContext.authorizer.custom:SUPER') ||\r\n 'false';\r\n let isSys = false;\r\n\r\n try {\r\n isSys = JSON.parse(jsonToParse);\r\n\r\n return isSys;\r\n } catch (e) {\r\n\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Throws unauthorized error if the user is not a super user.\r\n * Mirrors the behavior and style of checkModule but focused on SUPER role.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n */\r\nexport function checkIsSuper(event) {\r\n // Super or System users are always allowed\r\n if (isSuperUser(event)) {\r\n return;\r\n }\r\n if (isSystemUser(event)) {\r\n return;\r\n }\r\n\r\n // In local builds allow bypass to ease development and tests\r\n if (process.env.BUILD_ENV === 'local') {\r\n return;\r\n }\r\n\r\n throw errorList.unauthorized;\r\n}\r\n\r\n/**\r\n * Get the allowed businessIds for a user from the lambda event, compare it to businessIds, return what user has access to.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @param {{useCognitoBid:boolean}} [options] - An object with options, useCognitoBid prefers the businessId set in cognito if set and does not return the local bid of 1 if a bid is in the claim.\r\n * @returns {array} A list of businessIds that have been requested and are allowed to for some user.\r\n */\r\nexport function accessRightsUtils(event, options) {\r\n const useCognitoBid = _.get(options, 'useCognitoBid', false);\r\n const requestedBusinessIds = getRequestedBusinessIds(event);\r\n const allowedBusinessIds = getAllowedBusinessIds(event, useCognitoBid);\r\n\r\n if (isSuperUser(event)) {\r\n let v = requestedBusinessIds;\r\n if (_.isEmpty(requestedBusinessIds)) {\r\n v = allowedBusinessIds;\r\n }\r\n\r\n return v;\r\n }\r\n if (isSystemUser(event)) {\r\n return requestedBusinessIds;\r\n }\r\n\r\n if (requestedBusinessIds.length === 0) {\r\n return allowedBusinessIds;\r\n }\r\n\r\n return _.intersection(requestedBusinessIds, allowedBusinessIds);\r\n}\r\n\r\n/**\r\n * Get the businessID set in cognito as custom:DBI.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {string} The businessID set in cognito as custom:DBI\r\n */\r\nexport function userDefaultBid(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:DBI') ||\r\n _.get(event, 'requestContext.authorizer.custom:DBI') ||\r\n '{}';\r\n\r\n const dbi = JSON.parse(jsonToParse);\r\n return _.get(dbi, 'defaultBid', '') || '1';\r\n}\r\n\r\n/**\r\n * Get requested businessIds from the query string.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {array} The businessID requested by the query string\r\n */\r\nexport function getRequestedBusinessIds(event) {\r\n let requestedBusinessIds = _.get(event, 'queryStringParameters.businessIds', null);\r\n const body = parseBody(event);\r\n const bodyBid = body?.businessId;\r\n if (requestedBusinessIds) {\r\n return requestedBusinessIds ? requestedBusinessIds.split(',') : [];\r\n } else if (bodyBid) {\r\n return [ bodyBid ];\r\n } else {\r\n return [];\r\n }\r\n}\r\n\r\n/**\r\n * Get the allowed businessIds for a user from cognito custom:AR property.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @param useCognitoBid\r\n * @returns {array} The businessID requested by the query string\r\n */\r\nfunction getAllowedBusinessIds(event, useCognitoBid) {\r\n const businesses = getBusinessesInfo(event, useCognitoBid);\r\n return Object.keys(businesses);\r\n}\r\n\r\nexport function getAccessRightsInfo(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:AR') ||\r\n _.get(event, 'requestContext.authorizer.custom:AR') ||\r\n '{}';\r\n const accessRights = JSON.parse(jsonToParse);\r\n return _.get(accessRights, 'businessIds', {});\r\n}\r\n\r\nexport function getDefaultBusinessIDInfo(event) {\r\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:DBI') ||\r\n _.get(event, 'requestContext.authorizer.custom:DBI') ||\r\n '{}';\r\n const dbi = JSON.parse(jsonToParse);\r\n\r\n return _.get(dbi, 'defaultBid', {});\r\n}\r\n\r\nexport function getBusinessesInfo(event, useCognitoBid = false) {\r\n const json = _.get(event, 'requestContext.authorizer.claims.custom:AR') ||\r\n _.get(event, 'requestContext.authorizer.custom:AR') ||\r\n '{}';\r\n\r\n let businessIds = _.get(JSON.parse(json), 'businessIds', {});\r\n\r\n // Local environment tweaks\r\n if (process.env.BUILD_ENV === 'local') {\r\n let b;\r\n try {\r\n b = JSON.parse(event?.body);\r\n } catch (e) {\r\n }\r\n const bodyBid = b?.businessId;\r\n // Always inject the default local BID “1” unless the caller explicitly wants\r\n // what Cognito says **and** Cognito actually returned something.\r\n if (!useCognitoBid) {\r\n businessIds = { ...businessIds, '1': 'A' };\r\n }\r\n\r\n // If Cognito gave no BIDs at all, fall back to the local default.\r\n if (isEmpty(businessIds)) {\r\n businessIds = { '1': 'A' };\r\n }\r\n // a businessId is found on the body for local allow it\r\n if (bodyBid) {\r\n businessIds[bodyBid] = 'A';\r\n }\r\n }\r\n\r\n return businessIds;\r\n}\r\n\r\n/**\r\n * Get the modules listed in custom:MOD.\r\n *\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {array} The Module access list\r\n */\r\nexport function getModuleInfo(event) {\r\n let jsonToParse =\r\n _.get(event, 'requestContext.authorizer.claims.custom:MOD') ||\r\n _.get(event, 'requestContext.authorizer.custom:MOD') ||\r\n _.get(event, 'requestContext.authorizer.claims.custom:AR') ||\r\n _.get(event, 'requestContext.authorizer.custom:AR') ||\r\n\r\n '{}';\r\n\r\n const moduleRights = JSON.parse(jsonToParse);\r\n return _.get(moduleRights, 'module', {});\r\n}\r\n\r\n/**\r\n * Get the modules listed in custom:MOD.\r\n *\r\n * @param {string} moduleName - A sting name for a module.\r\n * @param {object} event - The lambda event passed in by a validated api request.\r\n * @returns {array} The Module access list\r\n */\r\nexport function checkModule(moduleName, event) {\r\n const moduleRights = getModuleInfo(event);\r\n let allowAccess = _.get(moduleRights, moduleName, false);\r\n\r\n if (isSuperUser(event)) {\r\n return;\r\n }\r\n if (isSystemUser(event)) {\r\n return;\r\n }\r\n\r\n if (process.env.BUILD_ENV === 'local') {\r\n return;\r\n }\r\n if (!allowAccess) {\r\n throw errorList.unauthorized;\r\n }\r\n}\r\n\r\nexport const userRoles = {\r\n admin: 'A',\r\n read: 'R',\r\n write: 'W'\r\n};\r\n\r\n/**\r\n * @param {{body: string}} event\r\n * @param {{useCognitoBid:boolean}} [options] - An object with options, useCognitoBid prefers the businessId set in cognito if set and does not return the local bid of 1 if a bid is in the claim.\r\n * @returns {string} businessId\r\n */\r\nexport function checkWriteAccess(event, options) {\r\n const eventBody = parseBody(event);\r\n const businessIds = accessRightsUtils(event, options) || [];\r\n const businessId = businessIds.find((id) => id === eventBody.businessId);\r\n const raw = getBusinessesInfo(event);\r\n const userRight = raw[businessId];\r\n\r\n if (isSuperUser(event)) {\r\n return eventBody.businessId;\r\n }\r\n\r\n if (isSystemUser(event)) {\r\n return eventBody.businessId;\r\n }\r\n\r\n if (process.env.BUILD_ENV === 'local') {\r\n return eventBody.businessId;\r\n }\r\n\r\n if ((userRight !== userRoles.admin && userRight !== userRoles.write) || (!userRight)) {\r\n throw errorList.unauthorized;\r\n }\r\n return businessId;\r\n}\r\n\r\n","import _ from 'lodash';\nimport DB from 'sequelize';\nimport dayjs from 'dayjs';\nimport utc from 'dayjs/plugin/utc.js';\nimport { errorList } from '../../../requestResponse/errorCodes.js';\nimport { accessRightsUtils } from './accessRightsUtils.js';\n\ndayjs.extend(utc);\n\n/**\n * Create sequelize where clause from query string parameters and default sort object\n *\n * @param {object} event - the query parameters from the event passed by lambda\n * @param {object} objectFilters - the default filters object created by createDefaultFilters\n * @returns {object} An sequelize where object\n */\nexport const createFilters = function (event, objectFilters) {\n let query = _.get(event, 'queryStringParameters', {}) || {};\n\n //searchString, startDate and endDate are bolted on as a convenience\n //startDate and endDate automatically get applied to createdAt\n //searchString allows you to search for a single string against many fields\n const searchString = _.get(query, 'searchString');\n const startDate = _.get(query, 'startDate');\n const endDate = _.get(query, 'endDate');\n\n const where = Object.keys(query).reduce((acc, item) => {\n const val = _.get(objectFilters, item, null);\n\n if (val) {\n const itemName = item.includes('.')\n ? `$${item}$`\n : item;\n\n acc[itemName] = {};\n if (val.filterType === DB.Op.iLike) {\n acc[itemName][val.filterType] = `%${query[item]}%`;\n } else if (val.filterType === DB.Op.or) {\n acc[itemName][val.filterType] = [-1 * +query[item], +query[item]];\n } else if (val.filterType === DB.Op.in) {\n acc[itemName][val.filterType] = query[item].split(',');\n } else if (val.filterType === DB.Op.in) {\n acc[itemName][val.filterType] = query[item].split(',');\n } else {\n let parsedJson;\n try {\n // value is JSON, parse it\n parsedJson = JSON.parse(query[item]);\n } catch (e) {\n // value is not JSON, pass through as a string\n parsedJson = query[item];\n }\n acc[itemName][val.filterType] = parsedJson;\n }\n\n if (val.type === DB.BOOLEAN) {\n const queryValue = _.get(query, item, '').toLowerCase();\n\n const booleanMap = {\n 'false': false,\n 'null': null,\n 'true': true\n };\n\n acc[itemName][val.filterType] = booleanMap[queryValue];\n }\n }\n\n return acc;\n }, {});\n\n if (objectFilters?.active && !where?.active) {\n where.active = true;\n }\n\n const businessIds = accessRightsUtils(event);\n const filterAdds = {\n businessId: businessIds\n };\n\n if (startDate && endDate) {\n const s = dayjs.utc(startDate);\n const e = dayjs.utc(endDate);\n const dates = {\n [DB.Op.between]: [s.toDate(), e.toDate()]\n };\n if (!s.isValid()) {\n throw { ...errorList.invalidStartDate };\n }\n\n if (!e.isValid()) {\n throw { ...errorList.invalidEndDate };\n }\n\n filterAdds.createdAt = dates;\n }\n\n if (searchString) {\n const adds = Object.keys(objectFilters).reduce((acc, item) => {\n const type = objectFilters[item].filterType;\n const dataType = objectFilters[item].type;\n\n if (type === DB.Op.iLike) {\n const newOr = {};\n const itemName = item.includes('.')\n ? `$${item}$`\n : item;\n newOr[itemName] = {\n [DB.Op.iLike]: `%${query['searchString']}%`\n };\n acc.push(newOr);\n }\n\n if (!_.isNaN(Number(query['searchString'])) && !(dataType instanceof DB.BOOLEAN)) {\n\n if (type === DB.Op.eq) {\n const newOr = {};\n const itemName = item.includes('.') ? `$${item}$` : item;\n newOr[itemName] = {\n [DB.Op.eq]: `${query['searchString']}`\n };\n acc.push(newOr);\n }\n }\n\n return acc;\n }, []);\n\n filterAdds[DB.Op.or] = adds;\n }\n\n const withDate = Object.assign(where, filterAdds);\n\n // Build nested objects for any JSONB fields defined in objectFilters\n Object.keys(objectFilters || {}).forEach((k) => {\n const def = objectFilters[k];\n if (def && def.type === 'jsonb' && def.field) {\n const prefix = `${def.field}.`;\n const nestedRoot = {};\n let found = false;\n\n Object.keys(query).forEach((qKey) => {\n if (qKey.startsWith(prefix)) {\n const path = qKey.substring(prefix.length);\n _.set(nestedRoot, path.split('.'), query[qKey]);\n found = true;\n }\n });\n\n if (found) {\n withDate[def.field] = nestedRoot;\n }\n }\n });\n\n return withDate;\n};\n","import _ from 'lodash';\n\n/**\n * Create sequelize includes array from query string parameters and default sequelize model\n *\n * @param {object} event - the query parameters from the event passed by lambda\n * @param {object} objectFilters - the default filters object created by createDefaultFilters\n * @returns {object} A sequelize includes array\n */\n\nexport function createIncludes(event, objectFilters) {\n const query = _.get(event, 'queryStringParameters', {}) || {};\n\n const keys = Object.keys(objectFilters);\n\n const canBeIncluded = keys.reduce((acc, item) => {\n acc = includeSubItem(item, acc);\n\n return acc;\n }, []);\n\n const askedForInQuery = Object.keys(query).reduce((acc, item) => {\n if (item === 'sort') {\n query[item].split(',').forEach((sortItem) => {\n sortItem = sortItem.indexOf('-') === 0 ? sortItem.substr(1) : sortItem;\n acc = includeSubItem(sortItem, acc);\n });\n }\n\n acc = includeSubItem(item, acc);\n\n return acc;\n }, []);\n\n return _.intersection(canBeIncluded, askedForInQuery);\n}\n\nexport function includeSubItem(queryStringItem, acc = []) {\n const dot = queryStringItem.indexOf('.');\n if (dot > 0) {\n acc.push(queryStringItem.substring(0, dot));\n }\n\n return acc;\n}","import _ from 'lodash';\n\n/**\n * Create sequelize order clause from query string parameters and default sort object\n *\n * @param {object} event - the event created AWS lambda, it will contain queryStringParameters with sort property a comma seperated list of sortable fields * @param {object} objectFilters - the default filters object created by createDefaultFilters\n * @param {object} defaultFilter - A default filter object as built by createDefault Filters, if items are not on the schema they will not be in the order by\n * @returns {object} An sequelize order by object\n */\nexport const createSort = function (event, defaultFilter) {\n let copyOfDefaultFilter = _.clone(defaultFilter);\n let query = _.get(event, 'queryStringParameters', {}) || {};\n let sort = _.get(query, 'sort', '-updatedAt') || '-updatedAt';\n\n return sort.split(',').reduce((acc, item) => {\n\n const testItem = item.indexOf('-') === 0 ? item.substr(1) : item;\n\n if (_.get(copyOfDefaultFilter, testItem, null)) {\n const sortItem = [];\n\n testItem.split('.').forEach((parentChildList) => {\n sortItem.push(parentChildList);\n });\n\n if (item.indexOf('-') === 0) {\n sortItem.push('DESC');\n } else {\n sortItem.push('ASC');\n }\n acc.push(sortItem);\n }\n\n return acc;\n }, []);\n};\n","import _ from 'lodash';\nimport DB from 'sequelize';\n\n/**\n * Create an object with default filters for a given sequeliaze Schema Object, and set of sub schemas\n *\n * @param {object} schema - type is sequelize data type\n * @param {object} subSchemas - An object with alias as the key and sequelize schema as the value http://docs.sequelizejs.com/class/lib/sequelize.js~Sequelize.html#instance-method-define\n * sub schema can be {location: locationSchema} or {location: {as: \"asAlias\", schema: schema}}\n * @returns {object} An Object with a default filter for each dataType CHAR and TEXT will get a $like operator, INTEGER, DECIMAL and BOOLEAN will get a $eq.\n */\nexport function defaultFilters(schema, subSchemas = {}) {\n schema = _.clone(schema);\n\n const filters = {};\n\n addFiltersFromSchema(schema, filters);\n Object.keys(subSchemas).forEach((key) => {\n addFiltersFromSchema(subSchemas[key], filters, key);\n });\n\n return filters;\n}\n\nexport function addFiltersFromSchema(schema, filters, keyPrefix = '') {\n const asLinkAlias = _.get(schema, 'as', null);\n schema = _.get(schema, 'schema') || schema;\n\n return Object.keys(schema).reduce((acc, item) => {\n let key = item;\n\n if (asLinkAlias) {\n acc[asLinkAlias] = { type: DB.STRING, filterType: DB.Op.eq };\n }\n\n if (keyPrefix) {\n key = `${keyPrefix}.${item}`;\n }\n\n if (schema[item].filterType) {\n acc[key] = { filterType: schema[item].filterType };\n\n return acc;\n }\n\n const itemType = schema[item].type;\n\n //new sequelize uses class symbols instead of objects\n if (itemType instanceof DB.STRING) {\n acc[key] = { filterType: DB.Op.iLike };\n } else if (itemType instanceof DB.CHAR) {\n acc[key] = { filterType: DB.Op.iLike };\n } else if (itemType instanceof DB.TEXT) {\n acc[key] = { filterType: DB.Op.iLike };\n } else if (itemType instanceof DB.DECIMAL) {\n acc[key] = { filterType: DB.Op.or };\n } else if (itemType instanceof DB.INTEGER) {\n acc[key] = { filterType: DB.Op.or };\n } else if (itemType instanceof DB.BIGINT) {\n acc[key] = { filterType: DB.Op.or };\n } else if (itemType instanceof DB.BOOLEAN) {\n acc[key] = { type: DB.BOOLEAN, filterType: DB.Op.eq };\n } else if (itemType instanceof DB.JSONB) {\n acc[key] = { type: itemType, filterType: DB.Op.contains };\n } else if (itemType instanceof DB.DATE) {\n acc[key] = { filterType: DB.Op.between };\n } else if (itemType instanceof DB.DATEONLY) {\n acc[key] = { filterType: DB.Op.eq };\n }\n\n //these are automatically part of the models so add them always\n acc['createdAt'] = { type: DB.DATE, filterType: DB.Op.between };\n acc['updatedAt'] = { type: DB.DATE, filterType: DB.Op.between };\n acc['id'] = { type: DB.INTEGER, filterType: DB.Op.eq };\n\n return acc;\n }, filters);\n}\n","/**\n * create pagination object from Sequelize findAll\n * @param {object} result - sequelize result\n * @param {number} limit - max number of results to return\n * @param {number} offset - page offset\n */\nexport function getPaginationFromFindAll(result, limit, offset) {\n result = result || [];\n limit = limit || 0;\n offset = offset || 0;\n\n const hasMore = result.length > limit;\n if (hasMore) {\n result.splice(-1, 1);\n }\n const pageObject = {\n offset: offset,\n limit: limit,\n rows: result,\n hasMore: hasMore\n };\n\n return pageObject;\n}\n\n/**\n * wrapper for Sequelize findAll\n * @param {object} model - instance of Sequelize (must be initialized)\n * @param {*&{include: [{model: *}], where: {businessId: Array}, order: [string[]]}} options - instance of Sequelize (must be initialized)\n */\nexport async function findAll(model, options) {\n\n const limit = options.limit || 0;\n const includes = options.includes || { all: true, nested: true };\n const findArgs = Object.assign({include: includes}, options, { limit: limit + 1 });\n const results = await model.findAll(findArgs);\n return getPaginationFromFindAll(results, limit, options.offset);\n}\n\nconst findUtils = {\n findAll\n};\nexport default findUtils;","import { DynamoDBDocument } from '@aws-sdk/lib-dynamodb';\nimport { DynamoDB } from '@aws-sdk/client-dynamodb';\n\nconst dynamoUtil = {\n get: (params) => get(params)\n};\n\n/**\n * @param {{TableName:string, Key:{key:string}}} params\n */\nasync function get(params) {\n const dynamoDb = DynamoDBDocument.from(new DynamoDB());\n return dynamoDb.get(params);\n}\n\nexport default dynamoUtil;","import { handleFile } from './handleFile.js';\nimport _ from 'lodash';\nimport Promise from 'bluebird';\n\nexport function handleEvents(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders = false, userImportTypes) {\n if (!event || !event.Records) {\n return Promise.resolve();\n }\n\n let hasErrors = false;\n\n return Promise.map(event.Records, (record) => {\n const snsInfo = JSON.parse(_.get(record, 'Sns.Message', '{}'));\n const s3Bucket = snsInfo.bucket;\n const files = snsInfo.files || [];\n\n return Promise.map(files, (file) => {\n let path = decodeURIComponent(file);\n if (path) {\n return handleFile(path, s3Bucket, transformer, { shouldSkipFailedFolders, userImportTypes }).catch((err) => {\n if (errorHandlerPerFile && !errorHandlerPerFile(err, path)) {\n console.error('HANDLE-FILE-CATCH: ', err);\n hasErrors = true;\n }\n });\n }\n });\n }).then(() => {\n if (hasErrors) {\n throw new Error('ERROR: HANDLE-FILE');\n }\n });\n}\n\nexport function handleDirectS3WriteEvent(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders = false, userImportTypes) {\n if (!event || !event.Records) {\n return Promise.resolve();\n }\n\n let hasErrors = false;\n\n return Promise.map(event.Records, (record) => {\n const s3Bucket = record.s3.bucket.name;\n const file = record.s3.object.key || [];\n\n let path = decodeURIComponent(file);\n if (path) {\n return handleFile(path, s3Bucket, transformer, { shouldSkipFailedFolders, userImportTypes }).catch((err) => {\n if (errorHandlerPerFile && !errorHandlerPerFile(err, path)) {\n console.error('HANDLE-FILE-CATCH:', err);\n hasErrors = true;\n }\n });\n }\n\n }).then(() => {\n if (hasErrors) {\n throw new Error('ERROR: HANDLE-FILE (DIRECT S3 EVENT)');\n }\n });\n}\n","import _ from 'lodash';\nimport S3Util from '../s3/S3Utils/S3Utils.js';\n\nexport async function handleFile(path, s3Bucket, transformer, options) {\n const shouldSkipFailedFolders = _.get(options, 'shouldSkipFailedFolders');\n const userImportTypes = _.get(options, 'userImportTypes');\n const params = {\n Bucket: s3Bucket,\n Key: path\n };\n let body;\n\n try {\n body = await S3Util.getObject(params);\n } catch (e) {\n console.error('no such file e.Code', e);\n if (e.Code === 'NoSuchKey' || e.code === 'NoSuchKey') {\n return;\n }\n throw e;\n }\n\n try {\n // exit early for null/undefined or blank string bodies\n if (_.isNil(body) || (_.isString(body) && _.isEmpty(body.trim()))) {\n await S3Util.deleteObject(params);\n return;\n }\n\n const parsedBody = JSON.parse(body);\n\n // exit early for objects like {} or []\n if (_.isEmpty(parsedBody)) {\n await S3Util.deleteObject(params);\n return;\n }\n\n const returnedValue = await transformer(parsedBody);\n await S3Util.deleteObject(params);\n\n return returnedValue;\n } catch (error) {\n console.error('HANDLE-FILE-ERROR', error);\n\n if (!body) {\n return;\n }\n\n let newPath = '';\n\n if (userImportTypes) {\n console.log('USER IMPORT');\n // look for items in the userImportTypes\n const usersImports = Object.values(userImportTypes);\n const items = path.split('/');\n const fileName = _.last(items);\n const folderName = _.first(items);\n\n if (usersImports.indexOf(folderName) > -1) {\n if (shouldSkipFailedFolders) {\n newPath = `${folderName}/error/${fileName}`;\n } else if (_.startsWith(path, `${folderName}/failed-once/`)) {\n newPath = _.replace(path, `${folderName}/failed-once/`, `${folderName}/failed-twice/`);\n } else if (_.startsWith(path, `${folderName}/failed-twice/`)) {\n newPath = _.replace(path, `${folderName}/failed-twice/`, `${folderName}/error/`);\n } else {\n newPath = `${folderName}/failed-once/${fileName}`;\n }\n } else {\n newPath = `pathAndEventMisMatchError/${path}`;\n }\n\n } else {\n if (shouldSkipFailedFolders) {\n newPath = `error/${path}`;\n } else if (_.startsWith(path, 'failed-once/')) {\n newPath = _.replace(path, 'failed-once/', 'failed-twice/');\n } else if (_.startsWith(path, 'failed-twice/')) {\n newPath = _.replace(path, 'failed-twice/', 'error/');\n } else {\n if (_.includes(path, 'delayUntil/')) {\n path = _.last(path.split('/'));\n }\n\n newPath = `failed-once/${path}`;\n }\n }\n\n const newParams = {\n Bucket: s3Bucket,\n Key: newPath,\n Body: body\n };\n\n if (\n containsError(newPath, 'failed-once') ||\n containsError(newPath, 'failed-twice') ||\n containsError(newPath, 'error')\n ) {\n throw new Error('NESTING ERROR');\n }\n\n await S3Util.putObject(newParams);\n await S3Util.deleteObject(params);\n\n throw error;\n }\n}\n\nexport function containsError(str, val) {\n const firstIndex = str.toLowerCase().indexOf(val);\n if (firstIndex === -1) return false;\n const secondIndex = str.toLowerCase().indexOf(val, firstIndex + 1);\n return secondIndex !== -1;\n}\n","import _ from 'lodash';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore';\nimport Promise from 'bluebird';\nimport S3Utils from '../s3/S3Utils/S3Utils.js';\nimport SNSUtil from '../sns/SNSUtils.js';\nimport dynamoUtil from '../dynamo/dynamoUtils.js';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(isSameOrBefore);\n\n/**\n * @param {string} bucket\n * @param {number} maxKeys\n * @param {Object} userImportTypes\n */\nexport async function loop(bucket, maxKeys, userImportTypes) {\n let bucketResult = {};\n let fileList = [];\n\n const currentTime = dayjs();\n\n do {\n bucketResult = await S3Utils.listObjectsV2({\n Bucket: bucket,\n MaxKeys: maxKeys,\n ContinuationToken: _.get(bucketResult, 'NextContinuationToken')\n });\n\n let newFiles = _.filter(bucketResult.Contents, (file) => {\n if (_.startsWith(_.get(file, 'Key'), 'delayUntil/')) {\n const fileDelayTime = _.get(file, 'Key').split('/')[1];\n return dayjs(fileDelayTime, 'YYYYMMDDHHmm').isSameOrBefore(currentTime);\n }\n if (userImportTypes) {\n // look for items in the userImportTypes\n const usersImports = Object.values(userImportTypes);\n const items = file.Key.split('/');\n const fileName = _.last(items);\n const folderName = _.first(items);\n if (_.isEmpty(fileName)) {\n return false;\n\n } else if (usersImports.indexOf(folderName) === -1) {\n return false;\n }\n\n return !_.startsWith(file.Key, `${folderName}/error`);\n }\n return !_.startsWith(file.Key, 'error');\n });\n\n fileList = _.concat(fileList, newFiles);\n } while (bucketResult.IsTruncated && bucketResult.NextContinuationToken && fileList.length < maxKeys);\n\n return fileList;\n}\n\n/**\n * Published SNS events at a steady pace for data in a particular bucket. Should be executed via a cloud watch cron job as a part of a micro service\n *\n * @param {string} configTable - The Dynamo DB table where to get the chunk-size and maxMessage size\n * @param {string} tableKey - The key to the item in the Dynamo DB table that holds the chunk-size and maxMessage size\n * @param {string} bucket - The name of the s3 bucket to watch, when you drop items into this table events will be created\n * @param {string} snsTopic - The name of the snsEvent to publish\n * @param {object} userImportTypes - import types to filter on\n */\nexport async function publishEvents(configTable, tableKey, bucket, snsTopic, userImportTypes) {\n let result;\n try {\n result = await dynamoUtil.get({\n TableName: configTable,\n Key: { key: tableKey }\n });\n } catch (e) {\n console.error(`Cannot get config for key: ${tableKey} table: ${configTable} falling back to defaults of 2 and 10`, e);\n }\n let chunkSize = _.get(result, 'Item.snsChunkSize', 2);\n let maxMessages = _.get(result, 'Item.snsMaxMessages', 10);\n\n const snsCreateTopicResponse = await SNSUtil.createTopic({ Name: snsTopic });\n const topicArn = snsCreateTopicResponse.TopicArn;\n const maxKeys = chunkSize * maxMessages;\n\n const fileList = await loop(bucket, maxKeys, userImportTypes);\n\n const messageList = _.chain(fileList)\n .map('Key')\n .chunk(chunkSize)\n .slice(0, maxMessages)\n .value()\n ;\n\n return Promise.map(messageList, (files) => {\n return SNSUtil.publish({\n Message: JSON.stringify({\n bucket: bucket,\n files: files\n }),\n TopicArn: topicArn\n });\n });\n}","import { publishEvents } from './publishEvents.js';\nimport { handleEvents, handleDirectS3WriteEvent } from './handleEvents.js';\nimport _ from 'lodash';\n\n/**\n * bucket watcher watches a s3 bucket and publishes events to a sns topic, this allows you to process files in s3 with a some transformer function\n * prefix objects with DIRECT to listen to direct s3 events\n *\n * @param {object} params - The parameters for watchBucket, see below\n * @param {object} params.event - The event of the lambda\n * @param {string} params.dynamoConfigTable - The Dynamo DB table where to get the chunkSize and maxMessage size\n * @param {string} params.dynamoConfigKey - The key to the item in the Dynamo DB table that holds the chunkSize and maxMessage size\n * @param {string} params.s3Bucket - The name of the s3 bucket to watch, when you drop items into this table events will be created\n * @param {string} params.snsTopic - The name of the snsEvent to publish\n * @param {function} params.transformer - the function to run on each file\n * @param {function} [params.errorHandlerPerFile] - the function to run on as a catch on each file\n * @param {boolean} [params.shouldSkipFailedFolders] - whether to use the failed-once, failed-twice, error or just error folders\n * @param {object} [params.userImportTypes] - user import subdirectories object map\n */\nexport function watchBucket({\n event,\n dynamoConfigTable,\n dynamoConfigKey,\n s3Bucket,\n snsTopic,\n transformer,\n errorHandlerPerFile = _.noop,\n shouldSkipFailedFolders = false,\n userImportTypes\n }) {\n if (!event || !dynamoConfigTable || !dynamoConfigKey || !s3Bucket || !snsTopic || !transformer) {\n throw new Error('Missing required parameters. Need event, dynamoConfigTable, dynamoConfigKey, s3Bucket, snsTopic, transformer');\n }\n\n const EventSource = _.get(event, 'Records[0].eventSource') || _.get(event, 'Records[0].EventSource');\n\n if (_.isEqual(EventSource, 'aws:sns')) {\n return handleEvents(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders, userImportTypes);\n } else if (_.isEqual(EventSource, 'aws:s3')) {\n const failedOnce = 'failed-once';\n const failedTwice = 'failed-twice';\n const error = 'error';\n const direct = 'DIRECT';\n const key = _.get(event, 'Records[0].s3.object.key') || '';\n const startsWithDirect = _.startsWith(key, direct);\n if (key.includes(failedOnce) || key.includes(failedTwice) || key.includes(error)) {\n // this used to throw, but the throw raised useless alarms, I believed turing throw in to a return was ok\n return;\n }\n\n if (startsWithDirect) {\n console.log('------->DIRECT WRITE FIRE');\n return handleDirectS3WriteEvent(event, transformer, errorHandlerPerFile, shouldSkipFailedFolders, userImportTypes);\n }\n\n } else {\n // the function is being run from the cron job so publish SNS events\n return publishEvents(dynamoConfigTable, dynamoConfigKey, s3Bucket, snsTopic, userImportTypes);\n }\n}\n","export const errorList = {\n invalidInventoryReleaseRequest: {\n message: 'NOT ENOUGH INVENTORY TO FULFILL RELEASE',\n errorCode: '4010',\n statusCode: 400\n },\n alreadyReleased: {\n message: 'ALREADY RELEASED',\n errorCode: '4011',\n statusCode: 400\n },\n alreadyReceived: {\n message: 'RECEIVABLE ALREADY RECEIVED',\n errorCode: '4012',\n statusCode: 400\n },\n invalidItemsRequest: {\n message: 'VALID ITEMS MUST BE INCLUDED',\n errorCode: '4013',\n statusCode: 400\n },\n invalidID: {\n message: 'ID is invalid',\n errorCode: '4014',\n statusCode: 400\n },\n invalidReceivable: {\n message: 'MUST CONTAIN AT LEAST ONE RECEIVABLE',\n errorCode: '4015',\n statusCode: 400\n },\n invalidRequest: {\n message: 'INVALID REQUEST DATA',\n errorCode: '4016',\n statusCode: 400\n },\n invalidAPIKey: {\n message: 'INVALID REQUEST - API MAY KEY INVALID',\n errorCode: '4017',\n statusCode: 400\n },\n qbCreationError: {\n message: 'QUICKBOOKS ERROR - ERROR CREATING OBJECT IN QUICKBOOKS',\n errorCode: '4018',\n statusCode: 400\n },\n cannotReopen: {\n message: 'CANNOT REOPEN - THE ORDER HAS ALREADY BEEN OPENED',\n errorCode: '4018',\n statusCode: 400\n },\n invalidDateFormat: {\n message: 'INVALID DATE FORMAT',\n errorCode: '4019',\n statusCode: 400\n },\n invalidStartDate: {\n message: 'INVALID START DATE',\n errorCode: '4020',\n statusCode: 400\n },\n invalidEndDate: {\n message: 'INVALID END DATE',\n errorCode: '4021',\n statusCode: 400\n },\n invalidOrderStatus: {\n message: 'UNABLE TO EDIT ORDER ITEMS UNLESS THE ORDER IS IN ESTIMATE STATUS',\n errorCode: '4022',\n statusCode: 400\n },\n invalidPaymentStatus: {\n message: 'UNABLE TO UPDATE PAYMENT STATUS PAYMENT MUST BE OPEN',\n errorCode: '4023',\n statusCode: 400\n },\n invalidReleaseStatus: {\n message: 'UNABLE TO UPDATE RELEASE, STATUS RELEASE MUST BE OPEN',\n errorCode: '4024',\n statusCode: 400\n },\n invalidReceivableStatus: {\n message: 'UNABLE TO UPDATE RECEIVABLE, STATUS RECEIVABLE MUST BE OPEN',\n errorCode: '40025',\n statusCode: 400\n },\n invalidJson:{\n message: 'INVALID JSON',\n errorCode: '4005',\n statusCode: 400\n },\n invalidFilter:{\n message: 'INVALID FILTER',\n errorCode: '4026',\n statusCode: 400\n },\n invalidUserNameUpdate:{\n message: 'UNABLE TO UPDATE USERNAME',\n errorCode: '4027',\n statusCode: 400\n },\n imageSizeLimit:{\n message: 'IMAGE SIZE LIMIT 100KB EXCEEDED',\n errorCode: '4028',\n statusCode: 400\n },\n unauthorized:{\n message: 'UNAUTHORIZED',\n errorCode: '4111',\n statusCode: 401\n },\n notFound:{\n message: 'ITEM NOT FOUND',\n errorCode: '4004',\n statusCode: 404\n },\n emailRequired:{\n message: 'NO EMAIL PROVIDED, CHECK CUSTOMER EMAIL',\n errorCode: '4004',\n statusCode: 404\n },\n mobilePhoneRequired:{\n message: 'NO MOBILE PHONE PROVIDED, CHECK CUSTOMER CONTACTS',\n errorCode: '4004',\n statusCode: 404\n },\n invalidCadenceType: {\n message: 'INVALID CADENCE TYPE',\n errorCode: '5001',\n statusCode: 500\n },\n};","import _ from 'lodash';\nimport { errorList } from './errorCodes.js';\n\n/**\n * @param {Object} body\n * @param {{dbClose?:function}} [options]\n */\nexport function success(body, options) {\n const dbClose = _.get(options, 'dbClose', _.noop);\n dbClose();\n\n return buildResponse(200, body);\n}\n\n/**\n * @param {string} html\n * @param {{dbClose:function|undefined}} options\n */\nexport function successHtml(html, options) {\n const dbClose = _.get(options, 'dbClose', _.noop);\n\n dbClose();\n return {\n statusCode: 200,\n headers: {\n 'Content-Type': 'text/html',\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Credentials': true\n },\n body: html\n };\n}\n\n/**\n * @param {string} event\n * @returns string\n */\nexport function getCurrentUserNameFromCognitoEvent(event) {\n const attributes = _.get(event, 'request.userAttributes');\n\n return attributes['cognito:email_alias'] || attributes['email'] || 'UNKNOWN USER';\n}\n\n/**\n * Get the user information from the event object\n *\n * @param event {Object} an event object\n * @returns {{username: string, id: number}}\n */\nexport function getCurrentUser(event) {\n let jsonToParse = _.get(event, 'requestContext.authorizer.claims.custom:UID') ||\n _.get(event, 'requestContext.authorizer.custom:UID') ||\n '0';\n\n const id = JSON.parse(jsonToParse);\n\n const username = _.get(event, 'requestContext.authorizer.claims.email') || _.get(event, 'requestContext.authorizer.email') || 'localtestuser@gexample.com';\n\n return {\n username,\n id\n };\n}\n\n/**\n * Create a failure response\n *\n * @param body {Object} an event object\n * @param options {Object} an options object\n * @returns {{statusCode:number, headers:object, body:string}} a response object\n */\nexport function failure(body = {}, options) {\n const dbClose = _.get(options, 'dbClose', _.noop);\n dbClose();\n let cleanedErrorBody;\n\n if (process.env.UTIL_LOG === 'LOG_ALL' || process.env.BUILD_ENV === 'test') {\n console.error('------->UTIL ERROR:', body);\n }\n\n const NORMAL_ERROR = { statusCode: 500, errorCode: '5XX', message: 'INTERNAL UTIL ERROR' };\n cleanedErrorBody = body;\n if (!_.isUndefined(body.details)) {\n cleanedErrorBody = detectJoyError(body);\n } else if (_.isUndefined(body.errorCode) || _.isUndefined(body.statusCode)) {\n cleanedErrorBody = detectSequelizeError(body);\n }\n if (_.get(body, 'response.data.message')) {\n console.error('------->UTIL ERROR: ' + _.get(body, 'response.data.message'));\n }\n console.log('>>>>cleanedErrorBody: ', cleanedErrorBody);\n\n const newBody = _.merge(NORMAL_ERROR, cleanedErrorBody);\n\n return buildResponse(newBody.statusCode, newBody);\n}\n\n/**\n * Create a failure response object\n *\n * @param statusCode {Number} a status code\n * @param body {Object} an event object\n * @returns {{statusCode:number, headers:object, body:string}} a response object\n */\nfunction buildResponse(statusCode, body) {\n return {\n statusCode: statusCode,\n headers: {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Credentials': true\n },\n body: JSON.stringify(body)\n };\n}\n\n/**\n * parse the body of the event object\n *\n * @param requestEvent {{body:string}} an event object\n * @returns event {*} the json object of the body\n */\nexport function parseBody(requestEvent) {\n\n let eventBody = {};\n if (_.isString(requestEvent.body)) {\n try {\n eventBody = JSON.parse(requestEvent.body);\n } catch (e) {\n // Invalid JSON\n eventBody = null;\n\n throw errorList.invalidJson;\n }\n } else if (_.isObject(requestEvent.body)) {\n eventBody = requestEvent.body;\n }\n\n return eventBody;\n}\n\n/**\n * parse the body of the event object\n *\n * @param requestEvent {string|object} an event object\n * @param [callback] {function} undefined a call back function\n * @returns event {*} the json object of the body\n */\nexport function parseEvent(requestEvent, callback) {\n let event = {};\n if (_.isString(requestEvent)) {\n try {\n event = JSON.parse(requestEvent);\n } catch (e) {\n // Invalid JSON\n event = null;\n\n if (callback) {\n callback(Error(e));\n }\n }\n } else if (_.isObject(requestEvent)) {\n event = requestEvent;\n }\n\n return event;\n}\n\n/**\n * parse the body of the event object\n * look for sequelize errors and return a message\n * ERRORS should not be caught here this is a fallback for unknown database errors\n *\n * @param body {object} part of a body response\n * @returns error message object {message:string}\n */\nexport function detectSequelizeError(body) {\n const errorBody = {};\n\n let sequelizeError = _.get(body, 'errors', []).reduce((acc, err) => {\n acc = acc + ' ' + _.get(err, 'message');\n return acc;\n }, '');\n const parentError = _.get(body, 'parent', '');\n\n sequelizeError = sequelizeError + _.get(body, 'original.detail', '') + _.get(body, 'TypeError', '') + parentError;\n errorBody.message = sequelizeError.trim();\n return errorBody;\n}\n\nexport function detectJoyError(body) {\n const errorBody = {};\n const joyError = _.get(body, 'details[0]', {});\n const additionalMessages = _.get(body, 'details[0].context.details') || [];\n\n const v = additionalMessages.reduce((acc, contextItem) => {\n acc = acc + ' ' + contextItem?.message || '';\n return acc;\n }, '');\n\n console.error('USER VALIDATION ERROR:', body);\n const msg = (joyError?.message || '') + v\n\n if (msg) {\n errorBody.message = _.trim(msg);\n }\n\n errorBody.statusCode = 400;\n errorBody.errorCode = '4000';\n return errorBody;\n}\n\n/**\n * Parse the body of a Dynamoose error response.\n * Attempts to extract a human-readable error message from Dynamoose errors.\n * This is a fallback for unknown database errors.\n *\n * @param {object} body - Part of a body response containing error details.\n * @returns {object} - Error message object { message: string }\n */\nexport function detectDynamooseError(body) {\n const errorBody = {};\n\n // Start with an empty message string.\n let dynamooseError = '';\n\n // If the error body contains an array of errors, concatenate their messages.\n if (Array.isArray(body.errors)) {\n dynamooseError += body.errors.reduce((acc, err) => {\n return acc + ' ' + (err.message || '');\n }, '');\n }\n\n // If there's a top-level message, add it.\n if (body.message) {\n dynamooseError += ' ' + body.message;\n }\n\n // If there is any additional detail provided, append it.\n if (body.detail) {\n dynamooseError += ' ' + body.detail;\n }\n\n // Trim the message to remove extra spaces.\n errorBody.message = dynamooseError.trim();\n\n return errorBody;\n}","import { S3 } from '@aws-sdk/client-s3';\n\nexport function s3Utils(action, params) {\n const s3 = new S3();\n return s3[action](params);\n}\n\nconst S3Util = {\n getObject: (params) => getS3(params),\n deleteObject: (params) => s3Utils('deleteObject', params),\n putObject: (params) => s3Utils('putObject', params),\n listObjectsV2: (params) => s3Utils('listObjectsV2', params)\n};\nexport default S3Util;\n\nasync function getS3(params) {\n const s3 = new S3();\n const response = await s3.getObject(params);\n return response?.Body.transformToString('utf-8');\n}","import { SNS } from '@aws-sdk/client-sns';\n\nconst SNSUtil = {\n publish: (params) => publish(params),\n createTopic: (params) => createTopic(params)\n};\n\nasync function publish(params) {\n const sns = new SNS();\n return await sns.publish(params);\n}\n\nasync function createTopic(params) {\n const sns = new SNS();\n return await sns.createTopic(params);\n}\n\nexport default SNSUtil;\n","module.exports = require(\"@aws-sdk/client-dynamodb\");","module.exports = require(\"@aws-sdk/client-s3\");","module.exports = require(\"@aws-sdk/client-sns\");","module.exports = require(\"@aws-sdk/lib-dynamodb\");","module.exports = require(\"bluebird\");","module.exports = require(\"dayjs\");","module.exports = require(\"dayjs/plugin/customParseFormat\");","module.exports = require(\"dayjs/plugin/isSameOrBefore\");","module.exports = require(\"dayjs/plugin/utc.js\");","module.exports = require(\"lodash\");","module.exports = require(\"sequelize\");","module.exports = require(\"umzug\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","import { handleFile as handleFileImport } from './eventManager/handleFile.js';\nimport { watchBucket as watchBucketImport } from './eventManager/watchBucket.js';\nimport { publishEvents as publishEventsImport } from './eventManager/publishEvents.js';\nimport { createIncludes as createIncludesImport } from './database/dbUtils/queryStringUtils/createIncludes.js';\nimport { createFilters as createFiltersImport } from './database/dbUtils/queryStringUtils/createFilters.js';\nimport { createSort as createSortImport } from './database/dbUtils/queryStringUtils/createSort.js';\nimport { findAll as findAllImport } from './database/dbUtils/queryStringUtils/findAll.js';\nimport { checkModule as checkModuleImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { checkIsSuper as checkIsSuperImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { getModuleInfo as getModuleInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { getAccessRightsInfo as getAccessRightsInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { getDefaultBusinessIDInfo as getDefaultBusinessIDInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { failure as failureImport, success as successImport } from './requestResponse/requestResponse.js';\nimport { runMigrations as runMigrationsImport } from './database/dbSetup/migrations.js';\nimport { getCurrentUser as getCurrentUserImport } from './requestResponse/requestResponse.js';\nimport { successHtml as successHtmlImport } from './requestResponse/requestResponse.js';\nimport { getCurrentUserNameFromCognitoEvent as getCurrentUserNameFromCognitoEventImport } from './requestResponse/requestResponse.js';\nimport { defaultFilters as defaultFiltersImport } from './database/dbUtils/queryStringUtils/defaultFilters.js';\nimport { accessRightsUtils as accessRightsUtilsImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { parseBody as parseBodyImport } from './requestResponse/requestResponse.js';\nimport { parseEvent as parseEventImport } from './requestResponse/requestResponse.js';\nimport { getBusinessesInfo as getBusinessesInfoImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { userDefaultBid as userDefaultBidImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { checkWriteAccess as checkWriteAccessImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { isSystemUser as isSystemUserImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\nimport { isSuperUser as isSuperUserImport } from './database/dbUtils/queryStringUtils/accessRightsUtils.js';\n\nexport const handleFile = handleFileImport;\nexport const watchBucket = watchBucketImport;\nexport const publishEvents = publishEventsImport;\nexport const createFilters = createFiltersImport;\nexport const createIncludes = createIncludesImport;\nexport const createSort = createSortImport;\nexport const findAll = findAllImport;\nexport const checkModule = checkModuleImport;\nexport const checkIsSuper = checkIsSuperImport;\nexport const getAccessRightsInfo = getAccessRightsInfoImport;\nexport const getDefaultBusinessIDInfo = getDefaultBusinessIDInfoImport;\nexport const getModuleInfo = getModuleInfoImport;\nexport const failure = failureImport;\nexport const success = successImport;\nexport const runMigrations = runMigrationsImport;\nexport const getCurrentUser = getCurrentUserImport;\nexport const successHtml = successHtmlImport;\nexport const getCurrentUserNameFromCognitoEvent = getCurrentUserNameFromCognitoEventImport;\nexport const defaultFilters = defaultFiltersImport;\nexport const accessRightsUtils = accessRightsUtilsImport;\nexport const parseBody = parseBodyImport;\nexport const parseEvent = parseEventImport;\nexport const getBusinessesInfo = getBusinessesInfoImport;\nexport const userDefaultBid = userDefaultBidImport;\nexport const checkWriteAccess = checkWriteAccessImport;\nexport const isSystemUser = isSystemUserImport;\nexport const isSuperUser = isSuperUserImport;\n"],"names":["async","runMigrations","databaseName","sequelizeInstance","initializeModels","pathToMigrationFolder","process","env","PWD","umzug","Umzug","migrations","glob","context","getQueryInterface","storage","SequelizeStorage","sequelize","logger","console","pendingMigrations","pending","log","up","catch","upError","error","down","_","chain","map","reverse","value","then","msg","Error","downError","_lodash2","_interopRequireDefault","e","__esModule","default","require","_umzug","isSystemUser","exports","isSuperUser","checkIsSuper","event","BUILD_ENV","errorList","unauthorized","accessRightsUtils","userDefaultBid","jsonToParse","get","dbi","JSON","parse","getRequestedBusinessIds","getAccessRightsInfo","accessRights","getDefaultBusinessIDInfo","getBusinessesInfo","getModuleInfo","checkModule","moduleName","moduleRights","allowAccess","checkWriteAccess","options","eventBody","parseBody","businessId","find","id","userRight","userRoles","admin","write","_lodash","_errorCodes","_requestResponse","isSys","useCognitoBid","requestedBusinessIds","allowedBusinessIds","getAllowedBusinessIds","businesses","Object","keys","v","isEmpty","length","intersection","body","bodyBid","split","json","businessIds","b","read","_sequelize2","_dayjs2","_utc2","_accessRightsUtils","dayjs","extend","utc","objectFilters","query","searchString","startDate","endDate","where","reduce","acc","item","val","itemName","includes","filterType","DB","Op","iLike","or","in","parsedJson","type","BOOLEAN","queryValue","toLowerCase","booleanMap","active","filterAdds","s","dates","between","toDate","isValid","invalidStartDate","invalidEndDate","createdAt","adds","dataType","newOr","push","isNaN","Number","eq","withDate","assign","forEach","k","def","field","prefix","nestedRoot","found","qKey","startsWith","path","substring","set","createIncludes","canBeIncluded","includeSubItem","askedForInQuery","sortItem","indexOf","substr","queryStringItem","dot","defaultFilter","copyOfDefaultFilter","clone","testItem","parentChildList","defaultFilters","schema","subSchemas","filters","addFiltersFromSchema","key","keyPrefix","asLinkAlias","STRING","itemType","CHAR","TEXT","DECIMAL","INTEGER","BIGINT","JSONB","contains","DATE","DATEONLY","getPaginationFromFindAll","result","limit","offset","hasMore","splice","rows","findAll","model","all","nested","findArgs","include","findUtils","_libDynamodb","_clientDynamodb","dynamoUtil","params","DynamoDBDocument","from","DynamoDB","handleEvents","transformer","errorHandlerPerFile","shouldSkipFailedFolders","userImportTypes","Records","Promise","resolve","hasErrors","record","snsInfo","s3Bucket","bucket","files","file","decodeURIComponent","handleFile","err","handleDirectS3WriteEvent","s3","name","object","_handleFile","_bluebird2","Bucket","Key","S3Util","getObject","Code","code","isNil","isString","trim","deleteObject","parsedBody","returnedValue","newPath","usersImports","values","items","fileName","last","folderName","first","replace","newParams","Body","containsError","putObject","_S3Utils2","str","firstIndex","loop","publishEvents","configTable","tableKey","snsTopic","TableName","chunkSize","maxMessages","topicArn","SNSUtil","createTopic","Name","TopicArn","maxKeys","fileList","messageList","chunk","slice","publish","Message","stringify","_customParseFormat2","_isSameOrBefore2","_SNSUtils2","_dynamoUtils2","bucketResult","currentTime","S3Utils","listObjectsV2","MaxKeys","ContinuationToken","newFiles","filter","Contents","fileDelayTime","isSameOrBefore","concat","IsTruncated","NextContinuationToken","customParseFormat","watchBucket","noop","dynamoConfigTable","dynamoConfigKey","EventSource","isEqual","failedOnce","failedTwice","direct","startsWithDirect","_publishEvents","_handleEvents","invalidInventoryReleaseRequest","message","errorCode","statusCode","alreadyReleased","alreadyReceived","invalidItemsRequest","invalidID","invalidReceivable","invalidRequest","invalidAPIKey","qbCreationError","cannotReopen","invalidDateFormat","invalidOrderStatus","invalidPaymentStatus","invalidReleaseStatus","invalidReceivableStatus","invalidJson","invalidFilter","invalidUserNameUpdate","imageSizeLimit","notFound","emailRequired","mobilePhoneRequired","invalidCadenceType","success","dbClose","buildResponse","successHtml","html","headers","getCurrentUserNameFromCognitoEvent","attributes","getCurrentUser","username","failure","cleanedErrorBody","UTIL_LOG","isUndefined","details","detectSequelizeError","detectJoyError","newBody","merge","requestEvent","isObject","parseEvent","callback","detectDynamooseError","errorBody","dynamooseError","Array","isArray","errors","detail","sequelizeError","parentError","joyError","contextItem","s3Utils","_clientS","action","S3","getS3","response","transformToString","_clientSns","sns","SNS","module","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","_watchBucket","_createIncludes","_createFilters","_createSort","_findAll","_migrations","_defaultFilters","handleFileImport","watchBucketImport","publishEventsImport","createFiltersImport","createIncludesImport","createSortImport","findAllImport","checkModuleImport","checkIsSuperImport","getAccessRightsInfoImport","getDefaultBusinessIDInfoImport","getModuleInfoImport","failureImport","successImport","runMigrationsImport","getCurrentUserImport","successHtmlImport","getCurrentUserNameFromCognitoEventImport","defaultFiltersImport","accessRightsUtilsImport","parseBodyImport","parseEventImport","getBusinessesInfoImport","userDefaultBidImport","checkWriteAccessImport","isSystemUserImport","isSuperUserImport"],"sourceRoot":""}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "piper-utils",
3
- "version": "1.1.21",
3
+ "version": "1.1.23",
4
4
  "description": "Utility library for Piper",
5
5
  "main": "bin/main.js",
6
6
  "scripts": {
@@ -198,8 +198,10 @@ export function detectJoyError(body) {
198
198
  }, '');
199
199
 
200
200
  console.error('USER VALIDATION ERROR:', body);
201
- if (joyError?.message || '' + v) {
202
- errorBody.message = _.trim(joyError?.message || '' + v);
201
+ const msg = (joyError?.message || '') + v
202
+
203
+ if (msg) {
204
+ errorBody.message = _.trim(msg);
203
205
  }
204
206
 
205
207
  errorBody.statusCode = 400;
@@ -304,9 +304,7 @@ describe('requestResponse', () => {
304
304
  ]
305
305
  };
306
306
  const r = detectJoyError(body);
307
- console.log('>>>>r: ', r);
308
-
309
-
307
+ expect(r).toEqual({ message: '"value" does not match any of the allowed types "businessId" is required "encryptedAccount" is required', statusCode: 400, errorCode: '4000' });
310
308
  });
311
309
  });
312
310
  });