Skip to main content

S3_Event

Node

Node Description

Node for triggering Flow upon receiving an S3 Event.

Node Attributes

  • input_filter_path
    • Input JSONPath used for applying filtering logic
  • input_trigger_flow_name
    • Input Ganymede flow to trigger from captured event

Notes

Prior to usage, the following secrets must be configured in the environment:

  • aws_s3_role_arn: AWS Service Account Name
  • s3_api_key: API key configured for EventBridge

This ARN will be used to enable the Airflow connection to the S3 bucket. Configuring this ARN will require the service account ID associated with the workflow orchestrator. Please reach out to the Ganymede team for instructions on configuring access within AWS to enable Ganymede connectivity. Once configured, add the AWS role ARN secret to your environment by clicking on your username in the upper-right hand of the Ganymede application, then selecting Environment Settings and navigating to the Secrets tab.

In addition to configuring role ARN, EventBridge must be configured to send events to Ganymede for the buckets that you would like to reference. The API destination for EventBridge should be configured to https://<your_tenant_name>/event/aws.

For more details on configuring EventBridge, visit https://docs.ganymede.bio/app/configuration/S3EventConfig.

Example

The example below shows the example-flow-to-trigger Flow being triggered when CSV files are loaded to test-folder in s3://environment-sandbox-s3-bucket/. The Trigger flow name is the ID of the Flow to trigger, which can be found in the Manage Flows panel on the Flow Editor page.

  • input_filter_path: detail.object.key.includes('test_folder')&&@.detail.bucket.name=='environment-sandbox-s3-bucket'&&@.detail.object.key.includes('.csv')
  • input_trigger_flow_name: example-flow-to-trigger

User-Defined Python

Calls AWS to get data for flow to trigger

Parameters

  • object_name : str
    • File name in S3 bucket
  • bucket_name : str
    • Name of S3 bucket
  • s3_hook: S3Hook
    • AWS S3 hook

Returns

FlowInputs Object containing data for kicking off subsequent Flow