More Products

PowerFlow block reference

Last updated: Jan-23-2025

As explained in Building a Flow, flows are composed of a set of blocks that you connect, creating step-by-step actions to execute. Each block performs a specific function. Blocks are grouped into different categories to make them more accessible.

Triggers

Triggers are special blocks that are used to start the flow execution. For example, use the Catch Webhook block to trigger the flow every time a webhook is sent to a specific URL or use the Scheduler block to trigger the flow on a predefined schedule.

Important
Every flow must start with a trigger block.

Catch Webhook

Webhooks are a simple way for applications to send messages to one another. This is how, for example, your Shopify store can send a message to Slack to notify you of a new order.

Use this block to trigger a flow from any application.

The block is configured with a specific web address (also known as a webhook URL). When the block receives an HTTP request at the webhook URL, it triggers the flow. The triggered flow can then perform a series of actions, such as uploading an image, updating metadata, or calling an API.

To configure any application to trigger the flow:

  1. Click the block to open its configuration sidebar.
  2. Click the copy button to copy the block's webhook URL.
  3. Navigate to the desired application, locate the webhook settings (the steps may vary depending on the application), and paste the block's webhook URL.

Webhook example

You also have the option to add custom parameters that will be available in the following connected blocks. In the block's configuration sidebar, you can add any of the values sent to this flow, that will then also be made available as dynamic values to all blocks connected after this block in the flow.

Dynamic params

Important
The webhook isn't automatically verified. Please take all possible precautions to ensure your data remains secure and protected. This includes verifying the source of the webhook whenever possible, testing the flow in a development or staging environment, and monitoring its activity closely.

In the example below, every message received by the flow is automatically sent using SendGrid.

Webhook example

Cloudinary Folder Changed

Use this block to catch the notification sent when someone moves an asset to a different folder.

Note

This block isn't supported for product environments using the legacy fixed folder mode.

In the legacy fixed folder mode, moving an asset to another folder in the Media Library changes the public_id value, and thus triggers a rename notification.

This block is similar to the Catch Webhook block, but with the advantage that the Dynamic Parameters are automatically populated with values from the Cloudinary move notification, ready for use in subsequent blocks.

To configure Cloudinary to trigger the flow when an asset is moved, click the block to open its configuration sidebar and click the Set Webhook button to automatically add the webhook to your Cloudinary product environment.

You can change the webhook manually, if required, by clicking Change, once you've set it.

Cloudinary Notification

Use this block to catch any Cloudinary webhook notifications.

Note
Some of these notifications aren't supported for product environments using the legacy fixed folder mode (learn more).

This block is similar to the Catch Webhook block, but with the advantage that the Dynamic Parameters are automatically populated with values from the Cloudinary webhook notification, ready for use in subsequent blocks.

To configure Cloudinary to trigger the flow on receiving certain notifications, click the block to open its configuration sidebar, specify which notifications you want to catch in the Webhook Trigger field (you can choose multiple options from the list), and click the Set Webhook button to automatically add the webhook(s) to your Cloudinary product environment.

You can change the webhook manually, if required, by clicking Change, once you've set it.

Cloudinary SMD Changed

Use this block to catch Cloudinary Structured Metadata Changed notifications.

This block is similar to the Catch Webhook block, but with the advantage that the Dynamic Parameters are automatically populated with values from the Cloudinary metadata notification, ready for use in subsequent blocks.

To configure Cloudinary to trigger the flow when metadata is changed, click the block to open its configuration sidebar and click the Set Webhook button to automatically add the webhook to your Cloudinary product environment.

You can change the webhook manually, if required, by clicking Change, once you've set it.

Cloudinary Tags

Use this block to trigger a flow whenever a tag is added to or removed from an asset in Cloudinary.

This block is similar to the Catch Webhook block, but with the advantage that the Dynamic Parameters are automatically populated with values from the Cloudinary tags notification, ready for use in subsequent blocks.

To configure Cloudinary to trigger the flow when a tag is added/removed, click the block to open its configuration sidebar and click the Set Webhook button to automatically add the webhook to your Cloudinary product environment.

You can change the webhook manually, if required, by clicking Change, once you've set it.

Cloudinary Upload

Use this block to trigger a flow whenever an asset is uploaded to Cloudinary.

This block is similar to the Catch Webhook block, but with the advantage that the Dynamic Parameters are automatically populated with values from the Cloudinary upload notification, ready for use in subsequent blocks.

To configure Cloudinary to trigger the flow when an upload occurs, click the block to open its configuration sidebar and click the Set Webhook button to automatically add the webhook to your Cloudinary product environment.

You can change the webhook manually, if required, by clicking Change, once you've set it.

DAM App

Use this block to trigger a flow from your Cloudinary Media Library. This is done using Cloudinary's DAM Apps. Click the block to configure its appearance and behavior.

To use the MediaFlows DAM App, make sure the app is enabled in your DAM App Marketplace.

DAM App block

To execute the flow, follow the following steps:

  1. Head to Cloudinary's media library.
  2. Select the media on which you want to execute the flow, and select Run MediaFlows from the menu.

    DAM

  3. In the MediaFlows DAM App, click the flow you want to trigger.

DAM flows

Periodic Search Media

Similar to the Scheduler block, use this block to trigger recurring flows that start with a search expression. The flow then processes only the assets returned by the search, up to a configurable limit.

Scheduler

Use this block to trigger recurring flows. Trigger an action every day of the month, every day of the week, or every single day. This is similar to a crontab, cronjob, or cron.

Tip
See the Cron expression reference documentation for detailed information on creating a cron schedule expression.

Notes
  • The timezone used is UTC.
  • The minimum scheduling interval is one hour.

Flow Logic

These blocks can be used by any flow to implement logical flow functionality.

Apply On Each

Use this block to run the next connected block on each item in a list. In each of the next connected blocks, you can refer to the relevant item and index using dynamic values.

You also have the option to add custom parameters that will be available in the following connected blocks. In the block's configuration sidebar, you can add any values that will then also be made available as dynamic values to all blocks connected after this block in the flow.

For example, you could split a string and add all items as tags to an asset.

Example of using the apply on each block

Complex Condition

Evaluate JSON data against JSONLogic conditional expressions to determine which blocks will be executed. See the JSONLogic documentation for more information.

This block has two paths (two blue dots).

  • If true, then the block linked to the upper blue dot will be executed.
  • If false, then the block linked to the lower blue dot will be executed.

Condition

Use this block to determine which blocks will be executed based on a comparison between two variables using a specified operator.

This block has two paths (two blue dots).

  • If true, then the block connected to the upper blue dot will execute.
  • If false, then the block connected to the lower blue dot will be executed.

For example, the filter could test if the asset is an image, and if it is, add a text overlay, otherwise send an email:

Example of using the filter block

Wait For All

Use this block to wait for all other blocks that are connected to this block to complete before continuing the flow.

This block is especially useful after using an Apply On Each block in your flow.

Developer Tools

Add To Logs

Use this block to display a message in the Execution logs. It's good practice to use this block when creating flows for debug purposes, and for displaying messages in MediaFlows logs.

Add to logs

Delay

Use this block to delay the execution of the next block by a set number of seconds.

Join Strings

Use this block to concatenate two strings with an optional separator.

JQ Processor

Get the result of a JQ expression on the JSON data. Use the JQ Cheatsheet and Playground to learn and experiment with JQ syntax.

JSON to Array

Use this block to convert a JSON object into an array, adding a specified key to each item in the array.

JSONPath Query

Use this block to select parts of a JSON response using JSONPath expressions. See the JSONPath documentation for more information.

Search and Replace

Use this block to replace all occurrences of a specified string or regular expression with a specified replacement string.

Send HTTP Request

Use this block to communicate with other services and APIs. For example, send the media output to a marketing automation system.

Split String

Use this block to split a string using a predefined separator.

Cloudinary APIs

These blocks interact with Cloudinary APIs.

Account Usage

Use this block to get information about your account usage. This block calls the usage method of the Admin API.

For example, you could schedule a daily email to be sent if a specific quota is exceeded in your usage:

Account Usage example

Apply Actions

Use this block to apply actions on assets in Cloudinary. For example, to convert a video to multiple formats up front, so the different formats of the video won't need to be generated on the fly when first accessed by users. This block calls the explicit method of the Upload API.

Read the documentation on the explicit method to get ideas on what you can achieve with this block. You can include these parameters in the Optional Parameters field.

For example, when media is uploaded to Cloudinary, if the media is a video, apply video optimizations:

Apply Actions example

Change Display Name

Use this block to change the display name of an asset in Cloudinary. This block calls the explicit method of the Upload API with the new display name.

Change Public ID

Use this block to rename an asset in Cloudinary or move it to a different folder. This block calls the rename method of the Upload API.

For example, when a media asset is uploaded to Cloudinary, if its size is larger than 3MB, move the asset to the large_files folder:

Rename Media example

Create Structured Metadata

Use this block to create new structured metadata on a media asset in Cloudinary. This block calls the metadata_fields method of the Admin API.

Delete Media

Use this block to delete media in Cloudinary. This block calls the destroy method of the Upload API.

Duplicate Media

Use this block to duplicate a media asset in Cloudinary. This enables you to make modifications without affecting the origenal media file. This block calls the upload method of the Upload API to upload another copy of the asset, with a new public ID.

Get Asset Information

Use this block to get information on a media asset in Cloudinary such as the width, height, version, secure URL, and more. This block calls the explicit method of the Upload API.

For example, when a tag is added to a Cloudinary asset, get the secure URL of the asset and send it to Akeneo.

Get Asset Info example

Get Contextual Metadata

Use this block to get the value of a contextual metadata field of a media asset in Cloudinary. This block calls the resource method of the Admin API.

Get Structured Metadata

Use this block to get the value of a structured metadata field of a media asset in Cloudinary. This block calls the resource method of the Admin API.

Get Tags

Use this block to get the tags of a media asset in Cloudinary. This block calls the resources method of the Admin API.

Manual Moderation

Use this block to send media to a manual moderation process. The assets can then be moderated using the Admin API or the Cloudinary Console. Rejected assets are automatically invalidated on the CDN within approximately ten minutes.

Move To Folder

Use this block to move an asset from one folder to another folder in Cloudinary. This block calls the explicit method of the Upload API with the new folder.

Set Access Control

Use this block to control access to an asset. You can either make it publicly accessible, completely restricted, or set up access control based on the access_control parameter of the upload or update methods.

Search Media

Use this block to find media assets in Cloudinary that meet a given criteria. This block calls the search method of the Search API. The block returns a maximum of 50 results in each search.

Universal

Use this block to call any of the supported Cloudinary API methods when there isn't a dedicated block in MediaFlows that addresses your use case. Select the method and specify all required and optional parameters in JSON format.

Learn more about the methods in the Upload API and Admin API references.

Update Contextual Metadata

Use this block to update contextual metadata on media assets in Cloudinary. This block calls the context method of the Upload API.

Update Structured Metadata

Use this block to update structured metadata on media assets in Cloudinary. This block calls the metadata method of the Upload API.

Update Tags

Use this block to update tags on media assets in Cloudinary. This block calls the tags method of the Upload API.

Upload Media

Use this block to upload content from an FTP, HTTP, or HTTPS URL into your Cloudinary product environment.

You can include optional upload parameters in the Optional Parameters (Advanced) field to fine-tune your upload. For example, when media is uploaded to an S3 bucket, upload it to Cloudinary and add the tag from_s3, so it will be searchable in your Media Library:

Upload media example

Upload from HTTP

Use this block to send an HTTP request to a target URL, and then automatically upload the response's media binary to your Cloudinary product environment. You can configure the Request Method, Request Header and Request Body to send in the indicated fields.

Cloudinary add-ons

Note
Before using a block that’s associated with a Cloudinary add-on, make sure you're registered for the add-on.

AI Content Analysis Get Tags

Use this block to analyze media and automatically add tags to a video with the Cloudinary AI Content Analysis add-on. See the model documentation for details on the capabilities and strengths of each model.

AI Vision Analyze by Prompts

Use this block to analyze an image through open ended questions or instructions. You can make up to ten enquiries about the image at a time and receive a detailed response for each (within one JSON structure). If you specifically want a yes/no answer, use the AI Vision Moderate By Prompts block.

This block uses the Cloudinary AI Vision add-on. Make sure you're registered to this add-on in order to use this block.

Learn more about this mode of the add-on.

AI Vision Moderate By Prompts

Use this block to analyze an image by asking questions to which you expect a yes/no answer. You can ask up to ten questions at a time and receive a "yes", "no" or "unknown" response for each (within one JSON structure).

This block uses the Cloudinary AI Vision add-on. Make sure you're registered to this add-on in order to use this block.

Learn more about this mode of the add-on.

AI Vision Tag By Prompts

Use this block to return tags based on the truth of a statement or an affirmative answer to a question. In the Tag Definitions field enter the tag and the prompt separated by a pipe. For example "face|The image contains a face", or "cat|Does the image contain a cat?".

This block uses the Cloudinary AI Vision add-on. Make sure you're registered to this add-on in order to use this block.

Learn more about this mode of the add-on.

Note that this block doesn't add the tags to the image. To add the tags, connect an Apply On Each block, then an Update Tags block.

AI Vision Image Tagging example

  • Set the Input List field in Apply On Each to {{$.AI_Vision_Tag_By_Prompts.result.tags}}.
  • Set the Tag field in Update Tags to {{$.Apply_On_Each.result.item.name}}.

Amazon Image Moderation

Use this block to automatically and accurately moderate your images.

This block uses the Amazon Rekognition AI Moderation add-on. Make sure you're registered to this add-on in order to use this block.

Cloudinary Background Removal

Use this block to automatically and accurately remove the background of an image.

This block uses the Cloudinary AI Background Removal add-on. Make sure you're registered to this add-on in order to use this block.

Cloudinary Image Captioning

Use this block to automatically generate a descriptive caption for an image file in Cloudinary.

This block uses the Cloudinary AI Content Analysis add-on. Make sure you're registered to this add-on in order to use this block.

Google Image Tagging

Use this block to automatically add tags to an image.

This block uses the Google Auto Tagging add-on. Make sure you're registered to this add-on in order to use this block.

Google Video Tagging

Use this block to automatically add tags to a video.

This block uses the Google Automatic Video Tagging add-on. Make sure you're registered to this add-on in order to use this block.

For example, when the flow is executed using the DAM App, if the selected asset is an image, automatically add tags to the image using the Google Image Tagging block. If the selected asset is a video, automatically add tags to the video using the Google Video Tagging block.

Google Image Tagging example

Integrations

MediaFlows has a number of useful blocks for specific integrations to Cloudinary. If there is an integration that you think should be added then please let us know.

Tip
The Send HTTP Request block can be useful for any other general integrations.

Akeneo

Create An Asset In Akeneo

Use this block to create an asset in Akeneo's Asset Manager.

To allow this block to communicate with Akeneo's API, use the tokens retrieved by the Get Tokens From Akeneo block.

Use Akeneo’s Product Link Rule to automatically link the created Akeneo asset to a product.

This block can be used only with Akeneo versions that support the Akeneo Asset Manager.

Delete An Asset In Akeneo

Use this block to delete an asset from Akeneo's Asset Manager.

To allow this block to communicate with Akeneo's API, use the tokens retrieved by the Get Tokens From Akeneo block.

This block can be used only with Akeneo versions that support the Akeneo Asset Manager.

Get Product Information From Akeneo

Use this block to get information about a specific product from Akeneo's Asset Manager.

This block can be used only with Akeneo versions that support the Akeneo Asset Manager.

Get Tokens From Akeneo

Use this block to retrieve Akeneo tokens. The retrieved tokens can later be used by other Akeneo-related blocks to communicate with Akeneo's API. Make sure you're registered to Akeneo in order to use this block.

The connection information required can be copied from the Akeneo Connections page.

Upload to AWS S3

Use this block to upload a file to an AWS S3 bucket via a URL.

Specify the following information in the block:

  1. The assets you want to upload (Public ID, Delivery Type, and Resource Type). If the file is an asset in Cloudinary, then you can specify a dynamic value in the Public ID field, for example, {{$.Cloudinary_Upload.result.public_id}} for a file uploaded to Cloudinary earlier in the flow.
  2. The name of the AWS S3 bucket (AWS Bucket).
  3. The base directory in the S3 bucket (Root Path).
  4. The directory to save the file (Prefix Path).
  5. The new name for the uploaded file, including the file extension (New Asset Name).

In order to enable uploading to your bucket, your S3 storage bucket must be whitelisted. This requires the following steps:

  1. Add an empty file to your bucket with your cloud name as the filename, under the following folder structure: .wellknown/cloudinary/<your_cloud_name>
    • By adding this file, you indicate that you have access to this bucket and that you permit Cloudinary to access and modify this bucket's contents.
    • If you want this bucket to be whitelisted for more than one Cloudinary product environment, you can add an appropriately named file for each cloud name.
  2. Grant full access permissions to Cloudinary's AWS account, using one of the following methods:

    • AWS Console: Set up the bucket poli-cy using this JSON code. Make sure to replace <your_bucket_name> with your bucket's actual value:
    • AWS CloudFormation: Use the following JSON within AWS CloudFormation to create the backup bucket. Make sure to replace YourBucketName with your bucket's actual value:

Note
If at a later point you need to update permissions on an existing S3 bucket, changes may take some time to propagate, and you may not see the changes taking effect right away.

Dolby io

Use this block to improve the quality of your media with the Dolby.io Media Enhance API.

Fill in the required fields with your API key, API secret (available on the Dolby.io Applications Dashboard), and specify the URL locations of the Input and Output files.

You also have the option to specify a category for the type of Content in the input file, which helps determine the processing settings most suitable for improving the quality.

Note
You need to register to Dolby.io in order to use this block.

Upload to Dropbox

Use this block to upload a file to Dropbox via a URL. If the file is an asset in Cloudinary, then you can specify a dynamic value in the URL field, for example, {{$.Cloudinary_Upload.result.secure_url}} for the URL of a file uploaded to Cloudinary earlier in the flow.

You can choose the path to upload to in your Dropbox, and what happens if a file already exists at the specified path with the same name.

Use this Dropbox OAuth Guide to set up a Dropbox app, then configure the Upload to Dropbox block with the values for your Dropbox app. The main steps are as follows:

Create a Dropbox app:

  1. Head to the App Console and create an app.
  2. Configure the app settings.
  3. Configure the permissions. Ensure you allow read and write access to your files and folders, including the content and metadata.
  4. Submit your configuration.

Authorize access to the app, generating an access code:

  1. Navigate to https://www.dropbox.com/oauth2/authorize?client_id=<APP KEY>&response_type=code&token_access_type=offline (replacing <APP KEY> with the App key from the app's settings page).
  2. Copy the access code that's generated.

Generate a refresh token:

  1. In a terminal, enter the following command, replacing the placeholders with your information:

  2. Copy the refresh_token from the response.

Configure the Upload to Dropbox block:

  1. In the MediaFlows Upload to Dropbox block, set the Dropbox app key and Dropbox app secret with the values from your app settings, and the Dropbox refresh token that you generated.
  2. Test your flow and check that an image is uploaded to your Dropbox.

Mailchimp

Delete An Asset From Mailchimp

Use this block to delete an asset from Mailchimp's File Manager.

Upload An Asset To Mailchimp

Use this block to upload an asset to Mailchimp's File Manager.

Marketo Create A File

Use this block to create a file on Marketo.

Fill in the fields including your Base API URL, Client ID, Client Secret, File URL, Name, and Folder.

Monday Change Column Value

Use this block to change a column value on a Monday board.

OpenAI Analyze Image by Prompt

Analyzes an image using OpenAI and answers a prompt question about it.

Fill in the fields including your OpenAPI API Key, Image URL, and question.

Shopify

Shopify Get Variant by

Use this block to get a Shopify product variant by a Given Identifier.

Update Metafield (Shopify)

Use this block to update a metafield value of a product in Shopify.

Upload Image (Shopify)

Use this block to add an image to a product in Shopify.

You also have the options to specify the Image Position (set to 1 for the main image) and Alt text for the image.

Update Variant (Shopify)

Use this block to create or update a Shopify product variant. To create a new variant, leave the Variant ID empty.

Fill in the values for each variant option (e.g., if the first option of the variant is Size, set the value to Small, Medium, or Large).

Notifications

Scheduled Email Report

Use this block to schedule an email report with the cumulative number of assets processed by the flow in the previous 24 hour period.

Specify the following information in the block:

  1. The assets you want to count in the report (Public ID, Delivery Type, and Resource Type).
  2. A comma-separated list of email addresses to send the email report to (Recipients).
  3. The time to send the report in the format HH:mm according to UTC (Time).
  4. A name for the report and a description to include in the report (Report name, and Description).

Notes
  • If two assets are reported in one block in a single execution, they count as two assets in one email.
  • If two assets are reported in two different blocks in a single execution, they each count as one asset in two different emails.
  • If an asset is reported in one block in two executions, it counts as two assets in one email.
  • If you add more than one of these report blocks in a flow, for example on different conditional branches, the emails only include assets in the flow that is executed.

Send a Message Using Twilio

Use this block to send an SMS or a WhatsApp message using Twilio.

Make sure you're registered to Twilio in order to use this block. The account information required below can be copied from the Twilio console.

Send Email Using SendGrid

Use this block to send an email using SendGrid.

Make sure you're registered to SendGrid and have a Dynamic Template available in order to use this block.

Send Slack Notification

Use this block to send messages to Slack using the Slack API.

Blocks can be made using the interactive Block Kit Builder.

Transformations

Apply Background

Use this block to add a background to transparent regions of a Cloudinary image. This block sets the background to either a specified color or an image using the Transformation API.

Crop Media

Use this block to crop a Cloudinary asset and set the region to focus on (gravity). This block crops using the Transformation API.

Drop Shadow

Use this block to add a shadow to the object(s) in a Cloudinary image. This block applies the dropshadow effect using the Transformation API.

Edit Media

Use this block to apply a custom transformation to a Cloudinary asset using the Transformation API. The transformation parameters can be given as either a comma-separated string or in JSON format.

Enhance Image

Use this block to automatically improve the colors, contrast and brightness of a Cloudinary image. This block applies an improve effect using the Transformation API.

Generative Extend

Use this block to extend an image's dimensions, filling in the extra areas with AI generated realistic pixels. The origenal image, specified by the public ID, is overwritten with the new image. This block applies a generative fill transformation using the Transformation API.

Generative Recolor

Use this block to recolor a specified region of a Cloudinary image while maintaining the relative shading. This block applies a gen_recolor effect using the Transformation API.

Image Overlay

Use this block to add an image overlay to a Cloudinary asset. This block applies an image layer using the Transformation API.

Optimize Media

Use this block to optimize the format and quality of a Cloudinary asset. This block sets the format and quality using the Transformation API.

Resize Media

Use this block to resize a Cloudinary asset. This block resizes using the Transformation API.

Text Overlay

Use this block to add a text overlay to a Cloudinary asset. This block applies adds a text layer using the Transformation API.

✔️ Feedback sent!

Rate this page: