npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

aws-sdk-wrap

v13.3.2

Published

Wrapper around aws-sdk

Downloads

2,961

Readme

AWS SDK Wrap

Build Status Test Coverage Dependabot Status Dependencies NPM Downloads Semantic-Release Gardener

Wrapper around aws-sdk.

Why

When dealing with the aws-sdk a lot, some calls become very repetitive and achieving code coverage becomes tiresome. This wrapper abstracts some of the repetitive logic.

Some examples of repetitive logic are:

  • having to call .promise()
  • handling of expected errors
  • logging of unexpected errors

Install

Install with npm:

$ npm install --save aws-sdk-wrap

Ensure required peer dependencies are available.

Usage

import AWS from 'aws-sdk-wrap';
import { S3Client, PutObjectCommand } from '@aws-sdk/client-s3';

AWS({
  services: {
    S3: S3Client,
    'S3:CMD': { PutObjectCommand }
  }
})
  .call('S3:PutObjectCommand', { /* ... */ })
  .then(/* ... */)
  .catch(/* ... */);

where the first parameter is the service, the second parameter is the method and the third parameter are the "params" passed into the call.

Services are lazily initialized on first access.

One can access an aws-sdk service directly by calling e.g. aws.get('S3').

Methods

call(action: String, params: Object = {}, options: Object = {})

The action is of the format path.to.service:functionName.

Gets the service from the underlying aws-sdk and initialize it with the available config iff the service is not initialized yet. Then calls the function with the passed params (which needs to contain the appropriate parameters for the function).

The available call options are detailed below.

get(serviceName: String)

Get the service from the underlying aws-sdk without initializing it. Possible to access nested paths.

updateGlobalConfig(AWS, config: Object)

Updates the global aws config of the passed aws-sdk via AWS.config.update. In most cases this should not be necessary to use.

sqs.sendMessageBatch({ messages: Array, queueUrl: String /* ... other options ... */ })

Splits messages into groups and calls sqs.SendMessageBatch for every group. Batch sizes can be modified by the batchSize option. Failed calls will be retried up to the maxRetries option. The available sendMessageBatch options are detailed below.

sqs.getDeadLetterQueueUrl({ queueUrl })

Return the Dead Letter Queue Url configured for the passed queue url

sqs.QueueProcessor({ queueUrls: String[], steps: Array, ingestSteps: String[] })

Initialize a queue processor lambda handler with steps. Steps need to be defined in the steps directory as separate STEPNAME.js files. Each queueUrl used by a step must be defined in queueUrls.

Each step should export:

  • schema<Joi>: Joi schema
  • handler<function(payload, event, stepContext): steps>: execution logic ingesting payload and event
  • next: array of next possible steps
  • queueUrl: the queue that the step is ingested into
  • delay = 0 (optional): the amount of seconds that the message is delayed, defaults to undefined, i.e. the queue default
  • retry = null (optional): Declare object that is then used to instantiate RetryError internally
  • timeout = 900 (optional): Timeout for individual step. Should allow for extra overhead for message management / processing and account for concurrency.
  • groupIdFunction = undefined (optional): Generator function for the groupId. Takes step payload as parameter
  • deduplicationIdFunction = undefined (optional): Generator function for the deduplicationId. Takes step payload as parameter
  • before<function(stepContext, payloads[]): steps> (optional): called before first step is executed
  • after<function(stepContext): steps> (optional):

The schema needs to define the event name under name. New events that are to be re-queued into the queue need to be returned from the handler, before or after function as an array.

Exposes:

  • ingest: Method used to seed queue. Note that messages generated inside a step should simply be returned from that step.
  • handler: Lambda function handler that is triggered by sqs
  • digraph: Visualize flow using viz-js.com.

Please see tests for example.

sqs.errors

  • RetryError: Can be thrown from step logic or declared on step to trigger (code) retry logic

sqs.prepareMessage(msg: Object, opts: Object)

Prepare message object with options. Currently options include:

  • delaySeconds (integer): used to set the delay for a specific message. Supersedes the corresponding batch option.
  • groupId (string): group id for the message, can only be set for steps that do not define groupIdFunction
  • deduplicationId (string): deduplication id for the message, can only be set for steps that do not define deduplicationIdFunction
  • urgent (boolean): message is immediately enqueued if returned from before or handler, instead of at the very end

s3.putGzipObject({ bucket: String, key: String, data: Object })

Adds an object to an Amazon S3 bucket gzipped. Uses s3:putObject.

s3.getGzipJsonObject({ bucket: String, key: String, expectedErrorCodes: [String] })

Retrieves objects from Amazon S3, expecting it to be gzipped. Uses s3:getObject.

s3.headObject({ bucket: String, key: String, expectedErrorCodes: [String] })

Retrieves only the metadata from an object in an Amazon S3 bucket. Uses s3:headObject.

s3.deleteObject({ bucket: String, key: String })

Delete object from an Amazon S3 bucket at key. Uses s3:deleteObject.

s3.listObjects({ bucket: String, limit: Number, startAfter: String, stopAfter: String, prefix: String })

List objects keys in an Amazon S3 bucket. Internally this pages until the limit is reached or no more keys are available. Uses s3:listObjectsV2.

  • stopAfter: If provided paging is stopped if the last key returned is larger or equal to this parameter. Only appropriate keys are then returned.

s3.decodeKey(key: String)

Returns a non-ASCII key representation for an encoded s3 key. Useful to obtain the not-encoded key representation after calling listObjects.

dy.Model({ name: String, attributes: Object, indices: Object, onNotFound: Function, onUpdate: Function, onCreate: Function })

Options details:

  • onNotFound (Function): Return value is returned from corresponding function. Return value is returned from corresponding function.
  • onUpdate (Function): Executed after an item is updated successfully.
  • onCreate (Function): Executed after an item is created successfully. Instantiates Model. Internally uses dynamodb-toolbox
dy.Model().createOrModify(item: Object, opts: Object)

Creates entry if key does not exist. Otherwise updates the item. Options include (all optional):

  • conditions (Object|Array): Conditions that must be met for operation to succeed.
  • expectedErrorCodes (Array): Provide string list of expected AWS error codes. Promise succeeds on expected error with error code as string.
  • toReturn (Array): Fields to return on item.

Internally uses update

dy.Model().createOrReplace(item: Object, opts: Object)

Creates entry if key does not exist. Otherwise replaces entire entry if item exists. Options include (all optional):

  • conditions (Object|Array): Conditions that must be met for operation to succeed.
  • expectedErrorCodes (Array): Provide string list of expected AWS error codes. Promise succeeds on expected error with error code as string.
  • toReturn (Array): Fields to return on item.

Internally uses put

dy.Model().modify(item: Object, opts: Object)

Edits an existing item's attributes. Can only update an item if it exists. Options include (all optional):

  • conditions (Object|Array): Conditions that must be met for operation to succeed.
  • onNotFound (Function): Overrides Model onNotFound function.
  • expectedErrorCodes (Array): Provide string list of expected AWS error codes. Promise succeeds on expected error with error code as string.
  • toReturn (Array): Fields to return on item.

Internally uses update

dy.Model().delete(key: Object, opts: Object)

Deletes an item. Can only delete an item if it exists. Options include (all optional):

  • conditions (Object|Array): Conditions that must be met for operation to succeed.
  • onNotFound (Function): Overrides Model onNotFound function.
  • expectedErrorCodes (Array): Provide string list of expected AWS error codes. Promise succeeds on expected error with error code as string.
  • toReturn (Array): Fields to return on item.

Internally uses delete

dy.Model().getItem(key: String, opts: Object)

Returns entry or null if not found. Options include (all optional):

  • toReturn (Array): Fields to return.
  • onNotFound (Function): Overrides Model onNotFound function.

Internally uses get

dy.Model().create(item: Object, opts: Object)

Creates entry if key does not exist. Otherwise errors. Options include (all optional):

  • conditions (Object|Array): Conditions that must be met for operation to succeed.
  • onAlreadyExists (Function): Overrides Model onAlreadyExists function.
  • expectedErrorCodes (Array): Provide string list of expected AWS error codes. Promise succeeds on expected error with error code as string.
  • toReturn (Array): Fields to return on item.

Internally uses put

dy.Model().query(key: String, opts: Object)

Pages through table based on primary key values. Options include (all optional):

  • index (String): Index name.
  • limit (Array): Maximum number of items to retrieve. If set to null, will exhaustively paginate.
  • consistent (Boolean): Enables ConsistentRead.
  • conditions (Object): Conditions that must be met for operation to succeed.
  • filters (Object): Conditions to filter the query results after execution (still executed on AWS).
  • toReturn (Array): Fields to return.
  • cursor (String): Cursor to page through query results.

Internally uses query

dy.Model().replace(item: Object, opts: Object)

Replaces entire entry if item exists. Otherwise errors. Options include (all optional):

  • conditions (Object|Array): Conditions that must be met for operation to succeed.
  • onNotFound (Function): Overrides Model onNotFound function.
  • expectedErrorCodes (Array): Provide string list of expected AWS error codes. Promise succeeds on expected error with error code as string.
  • toReturn (Array): Fields to return on item.

Internally uses put

dy.Model().scan(opts: Object)

Scans through every item in a table or secondary index. Options include (all optional):

  • index (String): Index name.
  • limit (Array): Maximum number of items to retrieve.
  • consistent (Boolean): Enables ConsistentRead.
  • filters (Object): Conditions to filter the query results after execution (still executed on AWS).
  • toReturn (Array): Fields to return.
  • lastEvaluatedKey (Object): Primary key of first item to be evaluated by operation.

Internally uses scan

dy.Model().schema

Returns subset of cloudformation template.

Init Options

services

Type: Object Default: N/A

AWS Services that should be available for this utility.

logger

Type: Logger Default: null

Provide logger. E.g. logplease or lambda-rollbar.

When an unexpected error is risen, information is logged using .error(...).

config

Type: Object Default: {}

AWS Config object used to initialize the service.

This only affects initialized services. To update the global AWS config use updateGlobalConfig.

configService

Type: Object Default: {}

Declare service specific configurations. E.g. configService = { dynamodb: { ... } }.

onCall

Type: Function Default: () => {}

Callback function that is called everytime after the AWS service is called, containing all information about the call and response.

Call Options

expectedErrorCodes

Type: list Default: []

Provide string list of expected AWS error codes. Promise succeeds on expected error with error code as string.

meta

Type: object Default: null

Provide additional debug information for failure case.

logger

Used to overwrite global logger. Set to null to prevent logging of errors.

SendMessageBatch Options

batchSize

Type: integer Default: 10

Specify the size of each batch that will be sent. Should never exceed 10.

maxRetries

Type: integer Default: 10

Number of times to retry any failed requests.

backoffFunction

Type: Function Default: (count) => 30 * (count ** 2)

The length of time the function will wait after each failed request before retrying.

delaySeconds

Type: integer Default: null

Set DelaySeconds option.