Hybrid Assets module

Edition

Incubator (services)

Issues

Git

Git

Latest

2.1.0

Compatible with Magnolia 6.2.

The Hybrid Assets module lets you store your asset metadata in the Magnolia DAM JCR implementation, but store the actual asset content outside of Magnolia in an external content store.

Hybrid assets are suited to:

  • very large assets, such as video or large images, that may not be easily stored in the JCR DAM

  • storing asset content in outside of Magnolia in a store that does not support full asset metadata, such as the Amazon S3 Connector module

  • external storage that cannot support the full DAM API

  • acting as a federated DAM with all asset entities and their metadata stored in one place while asset content is spread over storage locations and sources, including the Magnolia JCR DAM itself

The Hybrid Assets module can transfer asset content between several external storage locations and the Magnolia JCR DAM and import assets from external storage into the JCR DAM.

  • This module is at the INCUBATOR level.

  • If the Hybrid asset module version 1.0 is already installed in your system, please remove it before install version 2.0.

Installing with Maven

Maven is the easiest way to install the module. Add the following to your bundle:

  • Magnolia 6.2

  • Magnolia 5.7

Basic Hybrid assets app
<dependency>
  <groupId>info.magnolia.assets</groupId>
  <artifactId>magnolia-hybrid-assets-app</artifactId>
  <version>2.1.0</version>
</dependency>

Basic functions:

  • create

  • edit

  • delete

Configuration for mapping to S3 bucket: Replace CONFIGUREBUCKET with your bucket name

referenceFactory:
  class: info.magnolia.dam.hybrid.mapping.SimpleReferenceFactory
  mappings:
    referenceS3:
      class: info.magnolia.dam.hybrid.mapping.TransformReferenceMapping
      referenceTemplate: s3://CONFIGUREBUCKET/${baseName}-${nodeId}-${timestamp}.${extension}
      voters:
        mgnlDam:
          class: info.magnolia.dam.hybrid.voters.NodeWorkspaceVoter
stores:
  storeS3:
    class: info.magnolia.dam.hybrid.store.S3AssetStore
    description: S3 asset store
useExternalLinks: false
useExternalLinksInAuthor: false
#externalDomain: https://domain.com

Advanced Hybrid assets app
<dependency>
  <groupId>info.magnolia.assets</groupId>
  <artifactId>magnolia-hybrid-assets-advanced</artifactId>
  <version>2.1.0</version>
</dependency>

Advanced functions:

Function Description

Link external content

Create hybrid asset(s) linked to content in an external content store.

Export content

Transfers content from an existing asset to a designated location in an external content store.

Import external content

Transfers hybrid asset content stored in an external content store back into the Magnolia JCR DAM.

Refresh external content

Updates hybrid asset to force any stored images (like thumbnails) to be updated.

This is particularly useful when the linked external content has been updated.


Image recognition Hybrid assets compatibility
<dependency>
  <groupId>info.magnolia.assets</groupId>
  <artifactId>magnolia-hybrid-assets-img-recognition</artifactId>
  <version>2.1.0</version>
</dependency>

Image Recognition Compatibility:

<dependency>
  <groupId>info.magnolia.assets</groupId>
  <artifactId>magnolia-hybrid-assets</artifactId>
  <version>1.0</version>
</dependency>

Usage

Extensions to the Assets app

The Hybrid Asset module adds workbench actions to the Assets app:

Function Description

Link external content

Create hybrid asset(s) linked to content in an external content store.

Export content

Transfers content from an existing asset to a designated location in an external content store.

Import external content

Transfers hybrid asset content stored in an external content store back into the Magnolia JCR DAM.

Refresh external content

Updates hybrid asset to force any stored images (like thumbnails) to be updated.

This is particularly useful when the linked external content has been updated.

Linking to external content

The Hybrid Assets module can do more than just exporting asset content outside of Magnolia. It can also browse to storage outside of Magnolia and create hybrid assets from external content. We currently support to link content from Extended S3 connector and External Azure storage.

Hybrid assets under the hood

Storing asset content outside of Magnolia with hybrid assets is controlled by two configurable components: the reference factory and one or more external content stores. The reference factory determines where the content for an asset will be stored and the content stores handle the storing and retrieving of content outside of Magnolia.

Reference factory

The hybrid asset reference factory determines where the content of a hybrid asset will be stored. The reference factory can choose different locations for the content of an asset based on:

  • the JCR workspace of the asset

  • the path of the asset

  • the value of an asset property

  • the mime type of an asset

You can define multiple "mappings" in the reference factory. Each mapping defines a template for the destination of the asset content and voters that will determine if the mapping will be used to generate the destination of the content for a given asset

See External reference factory for more on configuring the reference factory and mappings.

External content stores

External content stores simply store asset content outside of Magnolia and allows hybrid assets to read and write their content. You define external content stores as part of your Hybrid Asset module configuration.

An external content must be configured with:

  • access credentials for the external store

  • specify what content the content store will read and write

See External content stores for more on configuring the content stores.

Image recognition

AWS has a size limitation for the image recognition service, in order to send big files to this service, the image recognition for hybrid assets provides a default configurable variation to resize the images over 5MB before sending them to the service. This value can be overridden decorating the module configuration with a new value, resizeWidth: 1024.

You can disable image recognition by setting in the configuration enabled: false and set a max size value to prevent the procesing of big images maxSize: 5000000.

cache

Cache can be configured like with external dams

damLinkField with Hybrid asset

To properly display asset information on the form when using damLinkField with a Hybrid asset, the class info.magnolia.dam.hybrid.field.HybridItemPreviewComponent should be included in the YAML configuration.

form:
  properties:
    image:
      $type: damLinkField
      preview:
        class: info.magnolia.ui.editor.ItemPreviewDefinition
        implementationClass: info.magnolia.dam.hybrid.field.HybridItemPreviewComponent

Versioning with S3 asset

Hybrid asset support you to effectively manage assets with versioning. You first need to enable versioning in the specific bucket where your assets are stored.

Versioning with Azure asset

Hybrid asset support you to effectively manage assets with versioning. You first need to enable versioning in the specific container where your assets are stored.

External Domain

This configuration allows to stream data directly form the external store. This is a preview feature that depends on the fastly-proxy module.

  • useExternalLinks: false

  • useExternalLinksInAuthor: false

  • externalDomain: https://domain.com

PDF and Video preview

In order to view the PDF/Video preview on the action bar, please set the value to true in your hybrid-assets/config.yaml:

  • displayPdfAndVideoPreview: true

Changelog

Version Notes

2.0.15

2.0.14

2.0.13

2.0.12

2.0.11

2.0.10

2.0.9

2.0.8

2.0.7

2.0.6

2.0.5

2.0.4

2.0.3

2.0.2

2.0.1

2.0

Compatible version with Magnolia 6.2

1.0

Initial release of the module.

Feedback

Incubators

×

Location

This widget lets you know where you are on the docs site.

You are currently perusing through the Hybrid Assets module docs.

Main doc sections

DX Core Headless PaaS Legacy Cloud Incubator modules