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 TypeMethodDescriptionbooleanaccepts(@NotNull MediaRequest mediaRequest) Checks whether a media request can be handled by this media sourceabstract booleanChecks whether a media request string can be handled by this media sourceabstract voidenableMediaDrop(@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 StringgetId()Get media source ID.protected final @Nullable CropDimensiongetMediaCropDimension(@NotNull MediaRequest mediaRequest, @Nullable MediaHandlerConfig mediaHandlerConfig) Get (optional) crop dimensions from resourceprotected final @NotNull StringgetMediaCropProperty(@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 StringgetMediaMapProperty(@NotNull MediaRequest mediaRequest, @NotNull MediaHandlerConfig mediaHandlerConfig) Get property name containing the image map parameterprotected final @Nullable StringgetMediaRef(@NotNull MediaRequest mediaRequest, @Nullable MediaHandlerConfig mediaHandlerConfig) Get media request path to media libraryprotected final @NotNull StringgetMediaRefProperty(@NotNull MediaRequest mediaRequest, @Nullable MediaHandlerConfig mediaHandlerConfig) Get property name containing the media request pathprotected final @Nullable IntegergetMediaRotation(@NotNull MediaRequest mediaRequest, @NotNull MediaHandlerConfig mediaHandlerConfig) Get (optional) rotation from resourceprotected final @NotNull StringgetMediaRotationProperty(@NotNull MediaRequest mediaRequest, @NotNull MediaHandlerConfig mediaHandlerConfig) Get property name containing the rotation parameterabstract @Nullable StringGet name of the property in which the primary media request is stored.abstract @NotNull MediaresolveMedia(@NotNull Media media) Resolves a media requestprotected final booleanresolveRenditions(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.voidsetCustomIPECropRatios(@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 voidupdateMediaArgsFromResource(@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
Get media source ID.- Returns:
- Media source ID
-
getPrimaryMediaRefProperty
Get name of the property in which the primary media request is stored.- 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)
-