Package io.wcm.handler.media.spi
Class MediaSource
java.lang.Object
io.wcm.handler.media.spi.MediaSource
- Direct Known Subclasses:
DamMediaSource
,InlineMediaSource
,NextGenDynamicMediaMediaSource
Via
MediaSource
OSGi services applications can define additional media sources supported by
MediaHandler
.
This class has to be extended by a Sling Model class. The adaptables
should be SlingHttpServletRequest
and Resource
.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionboolean
accepts
(@NotNull MediaRequest mediaRequest) Checks whether a media request can be handled by this media sourceabstract boolean
Checks whether a media request string can be handled by this media sourceabstract void
enableMediaDrop
(@NotNull io.wcm.handler.commons.dom.HtmlElement element, @NotNull MediaRequest mediaRequest) Create a drop area for given HTML element to enable drag and drop of DAM assets from content finder to this element.abstract @NotNull String
getId()
protected final @Nullable CropDimension
getMediaCropDimension
(@NotNull MediaRequest mediaRequest, @Nullable MediaHandlerConfig mediaHandlerConfig) Get (optional) crop dimensions from resourceprotected final @NotNull String
getMediaCropProperty
(@NotNull MediaRequest mediaRequest, @Nullable MediaHandlerConfig mediaHandlerConfig) Get property name containing the cropping parametersprotected final @Nullable List<ImageMapArea>
getMediaMap
(@NotNull MediaRequest mediaRequest, @NotNull MediaHandlerConfig mediaHandlerConfig) Get (optional) image map areas from resourceprotected final @NotNull String
getMediaMapProperty
(@NotNull MediaRequest mediaRequest, @NotNull MediaHandlerConfig mediaHandlerConfig) Get property name containing the image map parameterprotected final @Nullable String
getMediaRef
(@NotNull MediaRequest mediaRequest, @Nullable MediaHandlerConfig mediaHandlerConfig) Get media request path to media libraryprotected final @NotNull String
getMediaRefProperty
(@NotNull MediaRequest mediaRequest, @Nullable MediaHandlerConfig mediaHandlerConfig) Get property name containing the media request pathprotected final @Nullable Integer
getMediaRotation
(@NotNull MediaRequest mediaRequest, @NotNull MediaHandlerConfig mediaHandlerConfig) Get (optional) rotation from resourceprotected final @NotNull String
getMediaRotationProperty
(@NotNull MediaRequest mediaRequest, @NotNull MediaHandlerConfig mediaHandlerConfig) Get property name containing the rotation parameterabstract @Nullable String
abstract @NotNull Media
resolveMedia
(@NotNull Media media) Resolves a media requestprotected final boolean
resolveRenditions
(Media media, Asset asset, MediaArgs mediaArgs) Resolves single rendition (or multiple renditions if any of theMediaArgs.MediaFormatOption.isMandatory()
is set to true and sets the resolved rendition and the URL of the first (best-matching) rendition in the media object.void
setCustomIPECropRatios
(@NotNull io.wcm.handler.commons.dom.HtmlElement element, @NotNull MediaRequest mediaRequest) Sets list of cropping ratios to a list matching the selected media formats.protected final void
updateMediaArgsFromResource
(@NotNull MediaArgs mediaArgs, @NotNull org.apache.sling.api.resource.Resource resource, @NotNull MediaHandlerConfig mediaHandlerConfig) Updates media args settings that have default default values with values defined in the current resource that defines the media reference (e.g. alt. text settings).
-
Constructor Details
-
MediaSource
public MediaSource()
-
-
Method Details
-
getId
- Returns:
- Media source ID
-
getPrimaryMediaRefProperty
- Returns:
- Name of the property in which the primary media request is stored
-
accepts
Checks whether a media request can be handled by this media source- Parameters:
mediaRequest
- Media request- Returns:
- true if this media source can handle the given media request
-
accepts
Checks whether a media request string can be handled by this media source- Parameters:
mediaRef
- Media request string- Returns:
- true if this media source can handle the given media request
-
resolveMedia
Resolves a media request- Parameters:
media
- Media metadata- Returns:
- Resolved media metadata. Never null.
-
enableMediaDrop
public abstract void enableMediaDrop(@NotNull @NotNull io.wcm.handler.commons.dom.HtmlElement element, @NotNull @NotNull MediaRequest mediaRequest) Create a drop area for given HTML element to enable drag and drop of DAM assets from content finder to this element.- Parameters:
element
- Html elementmediaRequest
- Media request to detect media args and property names
-
setCustomIPECropRatios
public void setCustomIPECropRatios(@NotNull @NotNull io.wcm.handler.commons.dom.HtmlElement element, @NotNull @NotNull MediaRequest mediaRequest) Sets list of cropping ratios to a list matching the selected media formats.- Parameters:
element
- Html elementmediaRequest
- Media request to detect media args and property names
-
getMediaRef
@Nullable protected final @Nullable String getMediaRef(@NotNull @NotNull MediaRequest mediaRequest, @Nullable @Nullable MediaHandlerConfig mediaHandlerConfig) Get media request path to media library- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config (can be null, but should not be null)- Returns:
- Path or null if not present
-
getMediaRefProperty
@NotNull protected final @NotNull String getMediaRefProperty(@NotNull @NotNull MediaRequest mediaRequest, @Nullable @Nullable MediaHandlerConfig mediaHandlerConfig) Get property name containing the media request path- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config (can be null, but should not be null)- Returns:
- Property name
-
getMediaCropDimension
@Nullable protected final @Nullable CropDimension getMediaCropDimension(@NotNull @NotNull MediaRequest mediaRequest, @Nullable @Nullable MediaHandlerConfig mediaHandlerConfig) Get (optional) crop dimensions from resource- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config (can be null, but should not be null)- Returns:
- Crop dimension or null if not set or invalid
-
getMediaCropProperty
@NotNull protected final @NotNull String getMediaCropProperty(@NotNull @NotNull MediaRequest mediaRequest, @Nullable @Nullable MediaHandlerConfig mediaHandlerConfig) Get property name containing the cropping parameters- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config (can be null, but should not be null)- Returns:
- Property name
-
getMediaRotation
@Nullable protected final @Nullable Integer getMediaRotation(@NotNull @NotNull MediaRequest mediaRequest, @NotNull @NotNull MediaHandlerConfig mediaHandlerConfig) Get (optional) rotation from resource- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config- Returns:
- Rotation value or null if not set or invalid
-
getMediaRotationProperty
@NotNull protected final @NotNull String getMediaRotationProperty(@NotNull @NotNull MediaRequest mediaRequest, @NotNull @NotNull MediaHandlerConfig mediaHandlerConfig) Get property name containing the rotation parameter- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config- Returns:
- Property name
-
getMediaMap
@Nullable protected final @Nullable List<ImageMapArea> getMediaMap(@NotNull @NotNull MediaRequest mediaRequest, @NotNull @NotNull MediaHandlerConfig mediaHandlerConfig) Get (optional) image map areas from resource- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config- Returns:
- Rotation value or null if not set or invalid
-
getMediaMapProperty
@NotNull protected final @NotNull String getMediaMapProperty(@NotNull @NotNull MediaRequest mediaRequest, @NotNull @NotNull MediaHandlerConfig mediaHandlerConfig) Get property name containing the image map parameter- Parameters:
mediaRequest
- Media requestmediaHandlerConfig
- Media handler config- Returns:
- Property name
-
updateMediaArgsFromResource
protected final void updateMediaArgsFromResource(@NotNull @NotNull MediaArgs mediaArgs, @NotNull @NotNull org.apache.sling.api.resource.Resource resource, @NotNull @NotNull MediaHandlerConfig mediaHandlerConfig) Updates media args settings that have default default values with values defined in the current resource that defines the media reference (e.g. alt. text settings).- Parameters:
mediaArgs
- Media argsresource
- Resource with media referencemediaHandlerConfig
- Media handler config
-
resolveRenditions
Resolves single rendition (or multiple renditions if any of theMediaArgs.MediaFormatOption.isMandatory()
is set to true and sets the resolved rendition and the URL of the first (best-matching) rendition in the media object.- Parameters:
media
- Media objectasset
- AssetmediaArgs
- Media args- Returns:
- true if all requested mandatory renditions could be resolved (at least one or all if none was set to mandatory)
-