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 🙏

© 2026 – Pkg Stats / Ryan Hefner

@aws-mdaa/dataops-stepfunction

v1.6.0

Published

MDAA dataops-stepfunction module

Downloads

451

Readme

Step Functions

Note: This documentation is also available in a rendered format here.

Deploys Step Functions state machines with Amazon States Language definitions, EventBridge triggers (S3 notifications, scheduled, and custom rules), CloudWatch logging, and project KMS encryption. Use this module when you need to orchestrate multi-step data pipelines that coordinate Glue jobs, Lambda functions, and crawlers with branching logic, error handling, and retry strategies.


Deployed Resources

This module deploys and integrates the following resources:

Step Functions - State machines created for each specification in the configs

  • Configs can be hand crafted or directly specified as Amazon States Language (exported from AWS Console or CLI)

EventBridge Rules - Rules for triggering Step Functions with events such as S3 Object Created Events

  • EventBridge Notifications must be enabled on any bucket for which a rule is specified

dataops-stepfunction


Related Modules

  • DataOps Project — Deploy the shared project infrastructure (KMS keys) that Step Functions reference
  • ETL Jobs — Orchestrate Glue ETL jobs from within Step Functions state machines
  • Crawlers — Trigger crawlers from Step Functions for end-to-end pipeline orchestration
  • Lambda Functions — Invoke Lambda functions as steps within state machine workflows
  • Workflows — Alternative orchestration using Glue Workflows instead of Step Functions

Security/Compliance Details

This module is designed in alignment with MDAA security/compliance principles and CDK nag rulesets. Additional review is recommended prior to production deployment, ensuring organization-specific compliance requirements are met.

  • Encryption at Rest:
    • State machine data encrypted with project KMS key
  • Least Privilege:
    • Execution roles scoped to required state machine operations
    • EventBridge retry attempts and max event age configurable with DLQ for failed triggers

Configuration

MDAA Config

Add the following snippet to your mdaa.yaml under the modules: section of a domain/env in order to use this module:

dataops-stepfunction: # Module Name can be customized
  module_path: '@aws-mdaa/dataops-stepfunction' # Must match module NPM package name
  module_configs:
    - ./dataops-stepfunction.yaml # Filename/path can be customized

Module Config Samples and Variants

Copy the contents of the relevant sample config below into the ./dataops-stepfunction.yaml file referenced in the MDAA config snippet above.

Minimal Configuration

Deploys a single Step Functions state machine with a basic pass-through definition, wired to a DataOps project. Start here for a simple state machine within an existing DataOps project.

sample-config-minimal.yaml

# Contents available via above link
--8<-- "target/docs/packages/apps/dataops/dataops-stepfunction-app/sample_configs/sample-config-minimal.yaml"

Comprehensive Configuration

Exercises every non-excluded schema property at full depth. Start here when evaluating all available options for state machine definitions, EventBridge triggers, and logging configurations.

sample-config-comprehensive.yaml

# Contents available via above link
--8<-- "target/docs/packages/apps/dataops/dataops-stepfunction-app/sample_configs/sample-config-comprehensive.yaml"

Standalone Configuration (No Project)

Demonstrates standalone Step Functions with explicit KMS, bucket, deployment role, and security configuration. Use this when deploying outside of a DataOps project, providing infrastructure references directly.

sample-config-noproject.yaml

# Contents available via above link
--8<-- "target/docs/packages/apps/dataops/dataops-stepfunction-app/sample_configs/sample-config-noproject.yaml"

Express State Machine Configuration

Demonstrates an EXPRESS state machine type for high-volume, short-duration workflows. Choose this variant when your workflow executes frequently (e.g., event-driven microservices) and completes within five minutes, where cost-efficiency at high throughput is more important than exactly-once execution guarantees.

sample-config-express.yaml

# Contents available via above link
--8<-- "target/docs/packages/apps/dataops/dataops-stepfunction-app/sample_configs/sample-config-express.yaml"

Config Schema Docs