External Azure storage
The Hybrid Assets module lets you integrate external Azure Blob Storage assets into Magnolia.
Prerequisites
- 
Magnolia 6.2 
- 
An Azure Blob Storage account with: - 
Account name 
- 
Account key or Shared Access Signature (SAS) token 
- 
Container name 
 
- 
- 
A light module in your Magnolia instance for decorations 
Step 1: Configure Azure credentials
Store your Azure credentials securely using the Passwords app.
- 
Open the Passwords app in Magnolia. 
- 
Add the following entries under a node (e.g., /azure-credentials):- 
accountkey: Your Azure account key or SAS token.
- 
sig: Your Azure Shared Access Signature (if applicable).
 
- 
- 
Save the entries. 
 
Step 2: Update config.yaml for Hybrid Assets
In your light module, create or edit /modules/hybrid-assets/config.yaml to reference the credentials and configure the Azure store and reference factory.
For a full list of properties for Azure, see Azure external content store.
sig: 'azure-credentials/sig' (1)
accountKey: 'azure-credentials/accountkey' (1)
displayPdfAndVideoPreview: false
referenceFactory: (2)
  class: info.magnolia.dam.hybrid.mapping.SimpleReferenceFactory
  mappings:
    referenceAzure:
      class: info.magnolia.dam.hybrid.mapping.TransformReferenceMapping
      referenceTemplate: azure://hybridassets/test/#{baseName}.${extension} (3)
      voters: (4)
        mgnlDam:
          class: info.magnolia.dam.hybrid.voters.NodeWorkspaceVoter
stores:
  storeAzure: (5)
    class: info.magnolia.dam.hybrid.store.AzureAssetStore
    description: Azure Blob asset store
    enabled: true (6)
    baseUrl: 'blob.core.windows.net'
    endpointSuffix: 'core.windows.net'
    accountName: 'hybridAssets' (7)
    container: 'example-container' (8)
    pageSize: 10
    signedPermissions: 'racwd1' (9)
    signedStartTime: '2025-05-01T07:18:00Z' (10)
    signedExpiryTime: '2025-05-11T07:18:00Z' (10)
    serviceVersion: '2023-11-02'
    signedResource: 'c'| 1 | Paths to credentials stored in the Passwords app. | 
| 2 | The referenceFactorydefines how Azure assets are referenced in Magnolia using areferenceTemplate. | 
| 3 | The referenceTemplatespecifies the storage URL format for assets.Ensure the  | 
| 4 | votersdetermine when the mapping applies.
TheNodeWorkspaceVoterensures assets are in the DAM workspace. | 
| 5 | storeAzureconfigures the Azure Blob Storage connection. | 
| 6 | Ensure enabledistrue. | 
| 7 | accountNameis your Azure storage account name. | 
| 8 | containeris the Azure container holding your assets. | 
| 9 | signedPermissionsare the permissions for the SAS token (e.g.,racwd1for read, add, create, write, delete, list). | 
| 10 | signedStartTimeandsignedExpiryTimespecify the validity period for the SAS token (adjust based on your token). | 
| Optional parameters like signedResourceTypesorsignedServicescan be added for advanced setups.
See External content stores for details. | 
Azure external content store
The Hybrid Assets module also supports working with external Azure content storage: info.magnolia.dam.hybrid.store.AzureAssetStore.
The following are configurable properties of a Azure external content store:
| Property | Description | 
|---|---|
| 
 | required Must be  | 
| 
 | required Set to  | 
| 
 | optional A brief description of the external content store. | 
| 
 | required Base URL to build connection string to REST API. | 
| 
 | required The endpoint suffix to Azure storage. | 
| 
 | required Azure account name. | 
| 
 | required Azure container name. | 
| 
 | required Max results per request, default is 10. | 
| 
 | required Expiration time for token when getting blob url, default value is 1 hour. | 
| 
 | required The SAS can only be used over HTTPS, default value is 'https'. | 
| 
 | required Specifies the version of the service. | 
| 
 | required Grants read, write, delete, list, add, create, update, and process permissions. | 
| 
 | required Signed start time. | 
| 
 | required Signed expiry time. | 
| 
 | optional Grants access to service, container, and object. | 
| 
 | optional Grants access to service, container, and object. | 
| 
 | optional Grants access to the Blob service. | 
| 
 | optional More parameters that are optional and can be put in a dynamic requestParams configuration. | 
Step 3: Decorate the SubApp for linking Azure content
To enable the "Link external content" action for Azure assets, decorate the Hybrid Assets subApp.
- 
Create or edit /modules/hybrid-assets/hybridAssets.subApps.yamlin your light module.
- 
Override the linkContentaction to use thelinkAzureContentdialog.jcrBrowser: actions: linkContent: !override icon: icon-link class: info.magnolia.ui.dialog.actions.OpenDialogActionDefinition dialogId: hybrid-assets-advanced:linkAzureContent availability: root: true writePermissionRequired: true rules: notDeleted: $type: jcrIsDeletedRule negate: true
Step 4: Register the light module
Ensure your light module is registered by including a module.yaml file in the root of your light module.
This file ensures Magnolia applies your decorations in the correct order.
version: 1.0
dependencies:
  hybrid-assets-advanced:
    version: "*"Step 5: Test your configuration
- 
Restart your Magnolia instance. 
- 
In the Hybrid Assets app, use the Link external content action to connect to Azure assets. 
- 
Verify that assets from your Azure container appear and can be linked. 
Troubleshooting
- 
Credentials error: Ensure accountKeyandsigmatch the Passwords app entries.
- 
Assets not loading: Check accountName,container, and SAS token validity (signedStartTime,signedExpiryTime).
- 
Action not available: Confirm the hybridAssets.subApps.yamldecoration is applied correctly.
- 
Asset conflicts: Ensure the referenceTemplategenerates unique URLs to avoid overwriting assets. See External reference factory for guidance on unique templates.
For advanced users
For custom reference mappings, voters, or additional Azure store parameters, refer to External reference factory.