@mu-ts/sns
TypeScript icon, indicating that this package has built-in type declarations

2.1.0 • Public • Published

Summary

Easier AWS SNS interactions for both receipt and braodcasting of messages.

Class Decoration

In orderto do all the neat behaviors around an objet, we need a class to associate the configurations with.

You can use any of the decoration from @mu-ts/serilialization and it will be applied before publishing.

import { topic, groupId, subject, deduplicationId } from '@mu-ts/sns';

@topic('some:arn:to:some:topic')
class User {
  public id: string = 'uuid'

  @groupId
  public group: string = 'blue'

  @subject
  public name: string = 'Mr Jones'

  @deduplicationId
  public event: string = 'dedupe-1'

  @metadata()
  public owner: string ='owner-1'

  /**
   * Using the @mut-ts/serlization tag you can provide 'array' values
   * for message attributes.
   */
  @metadata((account: string ) => account.split('/'))
  public account: string = 'aprent/sub/child/account'
}

Message Attributes

You can add message attributes via the @mu-ts/serilization library, by tagging each field with the @metadata() decorator.

Behaviors

These are the commands you can use for interacting with an S3 bucket on a decorated object.

publish()

There are static/global functions and configurations as well as instance level ones.

Static

import { publish } from '@mu-ts/sns';

const user: user = new User()
user.id = ''
...

await publish(user);

Readme

Keywords

none

Package Sidebar

Install

npm i @mu-ts/sns

Weekly Downloads

62

Version

2.1.0

License

ISC

Unpacked Size

18.7 kB

Total Files

25

Last publish

Collaborators

  • matt-filion
  • strandedmusician
  • jeff-authvia