Product asset workflows
Last updated: Apr-02-2025
This section outlines an example workflow for managing product assets. Use these recommendations as a guide and change implementation to suite your company's needs.
Product asset workflows are largely automated. Once you link Cloudinary assets with specific products, they sync to the appropriate website components, already optimized and formatted for the ideal display.
Here's a diagram that shows the workflow for product assets:
Upload assets to Cloudinary
Upload assets directly to Cloudinary as the central source of truth for all images and videos via the upload endpoint, automated system triggers, or batch processing. Cloudinary automatically generates public IDs and delivery URLs for the assets.
Step 1: Create folder structure
You can organize folders based on content type—such as Clothing, Accessories, and Footwear—to improve searchability, enforce access control, and streamline asset management. A well-structured folder system helps users quickly locate assets and ensures permissions are assigned correctly.
To create a folder:
- Click the Folders tab at the top of the Media Library to navigate to that page.
- Click the Create a Folder icon at the top left corner.
- To create a subfolder, navigate to the parent folder first.
To share a folder:
- Select Share from the options drop-down next to the current folder path at the top of the Media Library
- Select the users and/or user groups you want to share the folder with, as well as the permission level for each.
For more information, see Folder management.
Step 2: Associate an asset with its product SKU
You might be able to retrieve essential metadata, such as SKU or unique product ID, and product information embedded within the asset files themselves (e.g., EXIF, XMP). Alternatively, you could pull this information from your PIM, database, or spreadsheet containing filenames, SKUs, and other relevant details.
Depending on your use case, you can associate the asset with its product SKU within Cloudinary using:
Method | What it does | When to use it | Implementation |
---|---|---|---|
Naming conventions | Embeds SKU into the asset's public ID to link products across platforms. | Use this method when you can only associate an asset with a single product. | Find out how to retrieve the product SKU: - If the SKU is part of the original file name, create an upload preset with - If you need to extract the SKU from another location, set the SKU as a See Step 5 and Step 6 for how to apply these settings within an upload preset. |
Metadata | Stores SKUs in metadata fields, tags, PIM, or databases for flexible retrieval. | Use this method when you can associate an asset with multiple products, or when product IDs aren't practical for SKU management. | 1 - Create a structured metadata field for storing SKUs. See Step 3. 2 - Set values for the SKU metadata field on your assets during upload. See Step 6. |
Step 3: Set up normalization
Normalization standardizes assets during upload, ensuring they meet your specific requirements for dimensions, format, and quality. This guarantees consistency across all assets and simplifies management.
This step entails creating named transformations to normalize product assets. You'll apply them on upload using an upload preset in Step 5.
Some common normalization actions include:
Normalization Action | What it Does | Considerations | Implementation |
---|---|---|---|
Background removal | Removes image backgrounds using AI. | Works well for large-scale operations. For finer results, use the Pexels add-on or FinalTouch. | Create a named transformation using the Transformation Builder. Apply the Background Removal action. |
Drop shadow | Adds realistic shadows to background-removed images. | Configures a virtual light source for natural shading. | Create a named transformation using the Transformation Builder. Apply the Drop Shadow action. |
Cropping and resizing | Adjusts images to a specific aspect ratio. | Use g_auto or g_object to keep key elements in focus for all fill and crop resize methods.If preserving the full image, use |
Create a named transformation using the Transformation Builder. When cropping with Fill or Crop actions, select Auto or Object from the Focus on drop-down to keep key elements in focus. When using the Pad resize action, select the Generative Fill option from Background Type to expand the background naturally. |
Trimming and removing sound | Cuts video clips and removes audio as needed. | Helps optimize video length and mute unwanted audio. | Create a named transformation using the Transformation Builder. Apply the Trim Video action to cut video clips. Click Quick Edit and enter |
Changing video orientation | Auto-adjusts video orientation to keep the subject in focus. | Use g_auto to ensure proper alignment across different devices. |
Create a named transformation using the Transformation Builder. Apply Crop, Fill, or Pad resize actions. Make sure to select Auto or Object from the Focus on drop-down to keep key elements in focus. |
Example:
- Configure named transformations using the Transformation Builder UI following these instructions:
- Open the Cloudinary Console.
- From the Programmable Media product, click Transformation Center, then New Transformation.NoteYou can use sample assets or select your own in the Transformation Builder to preview how transformations look when applied.
- Configure transformations via Select Action or Quick Edit, where you can enter any transformation string. TipLook up any transformation and find its string in the Transformation URL API reference.
Video Tutorial: Creating named transformations
Watch a short video that shows how to create named transformations in the Transformation Builder for normalizing product assets.
Step 4: Create metadata fields
Metadata can help system users, developers, or third-party stakeholders search for and retrieve assets for management or delivery. Retrieve metadata from information within the uploaded files themselves or your product management platform.
To define metadata in the Media Library:
- Go to the Structure Metadata page in the Console.
- Configure metadata. Consider creating:
-
SKU field of type
text
with external IDsku
-
Expiration field of type
date
with external IDexpiration_date
-
Visibility field of type
single select
with external IDvisibility
and list values Public and Private
-
SKU field of type
- The following options are available when creating and managing fields:
- Field types: Text, number, date, single-selection, and multiple-selection lists.
- Mandatory fields: Define required fields to ensure consistent metadata entry. (Make sure you set a realistic number of mandatory fields so your users don't get overwhelmed.)
- Default values: Assign default values to mandatory fields to prevent upload failures.
- List values: Specify predefined values for single- and multiple-selection fields.
-
Metadata rules: Set conditional rules (e.g., State field appears only if Country is US).
For more information, see Structured metadata.
Step 5: Register for add-ons
In order to enable some upload preset options, you first need to register for Cloudinary's add-ons. You'll then activate the selected add-ons using upload preset options in Step 5.
Here are some of the add-ons you may want to apply:
Add-on | What it Does | Considerations | Implementation |
---|---|---|---|
Google Auto Tagging | Automatically tags images using Google Vision AI. | Works well for general object recognition and categorization. | 1 - Register for the Google Auto Tagging add-on in the Cloudinary Add-ons Dashboard. 2 - Enable Google Auto Tagging in Addons page of a new upload preset. |
Amazon Rekognition Auto Tagging | Detects objects and assigns tags using Amazon Rekognition. | Useful for AI-powered object detection and scene analysis. | 1 - Register for the Amazon Rekognition Auto Tagging add-on. 2 - Enable Rekognition Auto Tagging in the Addons page of a new upload preset. |
Auto Moderation | Flags inappropriate content. | Ideal for content moderation and brand safety. | 1 - Register for the Rekognition AI Moderation and Rekognition AI Video Moderation add-on. 2 - Enable Rekognition AI Moderation (for images) or Rekognition AI Video Moderation (for videos) in the Addons page of a new upload preset. |
Cloudinary AI Content Analysis | Generates image captions and auto-tags assets. | Useful for automatic alt text and SEO improvements. | 1 - Register for the Cloudinary AI Content Analysis add-on. 2 - Enable Add AI captioning to your image for the Cloudinary AI Content Analysis add-on in the AI media processing section in the Addons page of a new upload preset. |
Google Video Intelligence | Labels objects and scenes in videos. | Ideal for video content classification. | 1 - Register for the Google Video Intelligence add-on. 2 - Enable Google Automatic Video Tagging in the Addons page of a new upload preset. |
Video Transcription and Translation | Generates video transcriptions and translates them into multiple languages. | Enhances accessibility, SEO, and multi-language support. | 1 - Register for the Video Transcription and Translation add-on. 2 - Enable Video Transcription and Translation in the Addons page of a new upload preset. |
Step 6: Use an upload preset for normalization, auto-tagging, access control, accessibility, and optimization
An upload preset enables you to centrally define a set of upload options, ensuring consistency and efficiency when uploading assets. It applies the options you set up in the previous steps, as well as other best practices for metadata, access control, normalization, accessibility, and optimization.
To create an upload preset to apply upload options:
Navigate to the Upload Presets tab of the Upload Console Settings page and click Add Upload Preset.
Use the table below to apply recommended upload preset options, see how they align with best practices, and learn how to implement them.
Option | How it Supports Best Practices | Implementation |
---|---|---|
Naming and folder location | Enforce naming conventions such as SKU association with the asset. Enforce governance within the organization and improve discoverability by uploading assets to meaningful folder locations. |
In the General tab of the new upload preset: - Enter the name of the Asset folder you want to upload to. - Select Use the filename of the uploaded file as the public ID to enforce naming conventions when the uploaded file contains the SKU. Note: If the SKU isn't part of the uploaded file's name and the SKU needs to be part of the public ID, set the SKU as a |
Normalize assets | Apply named transformations as incoming transformations to normalize the assets you store in Cloudinary. | In the Transform tab of the new upload preset, enter the name of the named transformation preceded by t_ :
Note: Instead of saving the normalized version of the asset in Cloudinary, you can save the original and generate a derived asset modified for later use. Do this by entering the named transformation as an Eager transformation, instead of Incoming. |
Improve image and video performance | Prepare responsive images for various viewports and use auto-format and quality settings to make sure your website loads quickly. | In the Transform tab of the new upload preset, add f_auto/q_auto as Eager transformations for various viewport sizes, e.g., w_320 , w_768 , w_1280 , w_1600 .
|
Enhance searchability with auto-tagging | Categorize assets accurately for faster search and retrieval while reducing manual effort. | In the Addons tab of the new upload preset, select the auto-tagging add-on(s). Make sure you're registered for those add-ons, as described in Step 4. |
Restrict access to assets with time based availability | Ensures sensitive assets are only available when needed. | In the Optimize and Deliver tab of the new upload preset, set Access control to Restricted, with an optional date range for unrestricted availability. |
Auto-generate captions | Use these captions as alt text to make images accessible to visually impaired users and improve SEO. | In the Addons tab of the new upload preset, select Add Al captioning to your image from the Cloudinary Al Content Analysis add-on. Make sure you're registered for the Cloudinary AI Content Analysis add-on, as described in Step 4. |
Generate video transcription and translations | Use video transcription and translation to make images and videos accessible to deaf and hard-of-hearing users and expand reach to multilingual audiences. | In the Manage and Analyze tab of the new upload preset, turn on Auto transcription and select the languages you want to provide. Make sure you're registered for the Video Transcription and Translation add-on , as described in Step 4. |
- Remember to click Save at the top left corner.
Step 7: Upload with an upload preset and metadata field values
Upload assets to Cloudinary with the upload preset applied, use:
- The upload endpoint of the Upload API for single asset or batch uploads.
- The migrate command of the Cloudinary CLI for batch uploads. Use this method for initiating uploads automatically from another source.
- The Media Library for manually uploading one or multiple assets, or a folder structure.
Examples:
- Upload using the use the upload endpoint, apply the
product_images
preset, and add metadata values for the SKU, Expiration (2 months from today), and Visibility fields:
-
Batch upload using the migrate command:
- Create an upload mapping to transfer assets from your source domain
https://your-source-domain.com/media/uploads/
to Cloudinary’sproduct_assets
folder
- Run this command to migrate all the assets listed in the
url_file.txt
to theproduct_assets
folder in your Cloudinary product environment, showing verbose output. Theproduct_assets
upload preset, which has the same name as the upload mapping, gets applied automatically:
- You can update metadata programmatically using the explicit endpoint.
- Create an upload mapping to transfer assets from your source domain
-
Upload assets to the Media Library:
- Navigate to the target folder:
- Open the Media Library and click the Folders tab.
- Browse to the folder where you want to upload assets.
-
Open the Upload Widget:
- Click Upload to launch the Upload Widget.
- Select an Upload Preset:
-
Upload the assets:
- Drag and drop the assets or folder structure into the Upload Widget.
- Bulk set metadata manually by selecting the assets you want to update and selecting Edit Structured Metadata from the assets toolbar.
- Update SKUs individually in the Media Library from the Metadata tab of the asset management drill-down page, or programmatically using the explicit endpoint.
Sync assets with your product data
After uploading your assets to Cloudinary, ensure they're linked to the other elements within your tech stack. Use product-identifying details (like SDK or product ID) in the asset's public ID or metadata for seamless integration.
Sync assets using a PIM integration
For businesses utilizing a PIM (Product Information Management) system, product information often exists in the PIM before adding assets to Cloudinary. Cloudinary serves as the central source of truth, allowing PIM systems to pull asset data, such as public IDs and delivery URLs directly from Cloudinary.
Key benefits of PIM integration:
Automatic syncing: Cloudinary delivery URLs or public IDs are stored in the PIM, enabling seamless product publishing with Cloudinary assets.
Consistent metadata: Cloudinary retrieves and syncs product metadata from the PIM to ensure consistency.
Bi-directional updates: Changes in the PIM automatically update in Cloudinary, and vice versa, ensuring the latest assets are always used.
Akeneo and Syndigo are examples of Cloudinary-integrated PIMs. See Integrations for a complete list.
Sync assets without a PIM integration
If you don’t use a PIM and instead manage product information through a database or spreadsheet, you can create a custom connector between Cloudinary and your system.
Essential components of a custom integration
Action | Purpose | Example |
---|---|---|
Set up webhook notifications | Receive real-time updates when API calls and Media Library actions complete. | Configure a webhook to notify your system whenever a new asset gets added. |
Save public IDs/URLs | Store asset identifiers in your database or spreadsheet for future reference. | Store Cloudinary public IDs alongside product SKUs in your database. |
Use MediaFlows for automation | Automate metadata updates and asset syncing between Cloudinary and external systems. | Set up an automation that updates asset tags in Cloudinary based on changes detected in your product database. |
Daily batch sync | Check for updates and synchronize metadata between Cloudinary and your system. | Use MediaFlows to run a scheduled job every night that syncs updated asset metadata. |
Bi-directional sync | Export asset public IDs and URLs from Cloudinary and import product information into Cloudinary. | Automatically sync product descriptions from your database to Cloudinary metadata fields. |
Read-only fields | Prevent Cloudinary metadata fields from being overwritten by external sources using the restrictions parameter within the metadata field structure. |
Lock the Cloudinary SKU metadata field, as it receives a value by importing metadata from your database. |
Additional considerations for integration
Make sure your connector is robust and handles all possible scenarios, such as asset deletion. Sync deletions from Cloudinary to your PIM or database.
-
Here's an example of a personalized flow that can help you manage metadata sync between Cloudinary and your system.
- Use a structured metadata field called Status.
- Set a value for the Status field dynamically:
- If all of the asset's required import successfully from your PIM or database to Cloudinary, set the Status field to Metadata complete.
- If any required fields are missing, set Status to Requires data.
- Create a saved search in Cloudinary to quickly find assets whose Status field's value is Requires data to manually complete the missing fields more easily.
Sample app: Syncing without a PIM integration
This PHP sample app adds products to a database and displays them in a product catalog with normalized images and videos. Videos undergo asynchronous moderation and are processed via webhook upon approval.
While this example provides a strong foundation, a real-world implementation would require modifying the process to retrieve assets and metadata programmatically instead of relying on user input, as well as enabling bulk uploads for efficiency.
Deliver product assets to your e-commerce website
Once you've organized assets in Cloudinary and linked them to your products, delivering them to your e-commerce website becomes an automated process. Whether using a pre-built integration or a custom implementation, Cloudinary dynamically optimizes and serves product images and videos based on product data and display requirements.
Method | What it does | Best for |
---|---|---|
Using an integrated front end | Cloudinary integrates directly with certain e-commerce platforms and headless CMSs, allowing assets to be retrieved and displayed automatically. | E-commerce stores with integrated platforms like Shopify, Salesforce Commerce Cloud, or commercetools. For a full listing, see Integrations. |
Using a standalone front end | Developers can programmatically fetch assets using Cloudinary’s APIs and SDKs, applying real-time transformations for optimization. | Custom-built websites, static sites, and SPAs without native Cloudinary integration. |
In both cases, you can use the Product Gallery Widget to deliver product assets dynamically on Product Detail Pages (PDPs). The Product Gallery Widget provides an interactive viewer that enhances product display with automatic image retrieval, video support, and 360° spin sets.
Using an integrated front end
If you’re using an e-commerce platform or a composable, headless front-end with built-in Cloudinary integration, follow the platform’s configuration and setup instructions to display your assets on your website efficiently.
-
E-commerce platform integrations
- Shopify: Utilize Cloudinary’s MediaFlows integration for seamless product asset delivery and rendering on Shopify stores, ensuring assets display as expected.
- Salesforce Commerce Cloud: Automate asset delivery using Salesforce Commerce Cloud Cartridges, ensuring efficient Cloudinary asset handling within your storefront.
-
Composable storefront integrations
- commercetools: Dynamically manage product assets for headless e-commerce experiences, providing flexibility in asset delivery.
- Salesforce Commerce Cloud Headless Cartridge: Enable Cloudinary image and video management through Salesforce’s headless commerce for seamless API-driven asset delivery.
Example: commercetools integration
A fully functional demo showcases the commercetools extension, offering insights into setting up a storefront and displaying product assets effectively. Developers can reference the GitHub repository for implementation details.
Using a standalone front end
If your platforms don't include a ready-made Cloudinary integration, you'll need to implement your own solution to render your Cloudinary assets on your front-end.
Use Cloudinary's SDKs to seamlessly integrate assets (and optionally the Product Gallery Widget) into headless front-end applications (such as React, React Native, Android, etc.). Dynamically assign assets to website components using product-match workflows.
Step 1: Schedule publishing
Automatically initiate the process of publishing assets using MediaFlows or cron jobs, ensuring your assets are always up-to-date on your website without manual intervention.
Here's an example MediaFlow that sends an HTTPS request to update your front-end with any new or updated Cloudinary assets any on a schedule, such as once a day:
Step 2: Set up optimization and adjustments according to website location
Use named transformations dynamically modify product images based on their display location (e.g., PDPs, PLPs) while ensuring optimal format and quality. Once created, a named transformation can be applied repeatedly on delivery without additional setup.
Here's an example of a named transformation (pdp_product_images
), created programmatically, that applies cropping, resizing, format conversion, and quality adjustments:
Step 3: Search, retrieve, and render product assets
To display the correct assets on your website, retrieve each asset by its SKU (or another product identifier). You can store the SKU as part of the public ID or within the asset’s metadata. This approach ensures each asset matches the correct product and display location, such as PDPs or PLPs.
The following example creates a delivery URL for an asset using the SKU stored in the metadata field. It applies the pdp_product_images
named transformation to optimize the image for a PDP:
Enhancing product asset display with the Product Gallery Widget
Cloudinary’s Product Gallery Widget is a ready-to-use, interactive viewer that simplifies product asset presentation. It requires only JavaScript, making it easy to integrate into any web framework while eliminating the need for custom gallery development.
Benefits:
- Seamless integration: Embed a responsive, media-rich product gallery.
- Automatic asset population: Retrieves product images and videos based on tags.
- Customizable layouts: Adjust styles, transitions, and navigation.
- 360° spin sets: Enable interactive product exploration with rotational image sets.
Factor | Considerations |
---|---|
Performance | If page speed is a priority, use pre-optimized static images instead of the fully interactive Product Gallery Widget. |
Customization | Modify layouts, navigation, and transitions to match your design. |
Optimization | Apply Cloudinary’s transformations to ensure images and videos load efficiently on every device. |
Implementation:
For integrated front-ends, check your integration's documentation for specific instructions on embedding the Product Gallery Widget.
For custom front-ends, include the remote JavaScript file and initialize the widget with:
Other delivery channels
Besides delivering non-product images on your website, you can also deliver to the following channels:
Social media: Optimize images for different platform size and format requirements.
Third-party stakeholders: Ensure compliance with background color or file format constraints and protect your assets by watermarking.
Email campaigns: Maintain quality within file size and resolution limitations.
Market places: Adhere to specific format, background, metadata, and naming rules.
For more information, see Multi-channed content delivery.