@ProviderType
public interface ModelFactory
| Modifier and Type | Method and Description |
|---|---|
boolean |
canCreateFromAdaptable(@NotNull java.lang.Object adaptable,
@NotNull java.lang.Class<?> type) |
<ModelType> |
createModel(@NotNull java.lang.Object adaptable,
@NotNull java.lang.Class<ModelType> type)
Instantiates the given Sling Model class from the given adaptable.
|
<T> T |
exportModel(@NotNull java.lang.Object model,
@NotNull java.lang.String exporterName,
@NotNull java.lang.Class<T> targetClass,
@NotNull java.util.Map<java.lang.String,java.lang.String> options)
Export the model object using the defined target class using the named exporter.
|
<T> T |
exportModelForRequest(@NotNull SlingHttpServletRequest request,
@NotNull java.lang.String exporterName,
@NotNull java.lang.Class<T> targetClass,
@NotNull java.util.Map<java.lang.String,java.lang.String> options)
Export the model object registered to the request's resource's type using the defined target class using the named exporter.
|
<T> T |
exportModelForResource(@NotNull Resource resource,
@NotNull java.lang.String exporterName,
@NotNull java.lang.Class<T> targetClass,
@NotNull java.util.Map<java.lang.String,java.lang.String> options)
Export the model object registered to the resource's type using the defined target class using the named exporter.
|
@NotNull java.lang.Object |
getModelFromRequest(@NotNull SlingHttpServletRequest request)
Obtain an adapted model class based on the resource type of the request's resource.
|
@NotNull java.lang.Object |
getModelFromResource(@NotNull Resource resource)
Obtain an adapted model class based on the resource type of the provided resource.
|
<T> T |
getModelFromWrappedRequest(@NotNull SlingHttpServletRequest request,
@NotNull Resource resource,
@NotNull java.lang.Class<T> targetClass)
Create a wrapped request object with the specified resource and (try to) adapt the request object into the specified class.
|
boolean |
isModelAvailableForRequest(@NotNull SlingHttpServletRequest request)
Determine is a model class is available for the request's resource's resource type.
|
boolean |
isModelAvailableForResource(@NotNull Resource resource)
Determine is a model class is available for the resource's resource type.
|
boolean |
isModelClass(@NotNull java.lang.Class<?> type)
Checks if a given type can be instantiated though Sling Models.
|
boolean |
isModelClass(@NotNull java.lang.Object adaptable,
@NotNull java.lang.Class<?> type)
Deprecated.
Use
isModelClass(Class) instead! |
@NotNull
<ModelType> ModelType createModel(@NotNull
@NotNull java.lang.Object adaptable,
@NotNull
@NotNull java.lang.Class<ModelType> type)
throws MissingElementsException,
InvalidAdaptableException,
ModelClassException,
PostConstructException,
ValidationException,
InvalidModelException
adaptable - the adaptable to use to instantiate the Sling Model Classtype - the class to instantiatenull)MissingElementsException - in case no injector was able to inject some required values with the given typesInvalidAdaptableException - in case the given class cannot be instantiated from the given adaptable (different adaptable on the model annotation)ModelClassException - in case the model could not be instantiated because model annotation was missing, reflection failed, no valid constructor was found, model was not registered as adapter factory yet, or post-construct could not be calledPostConstructException - in case the post-construct method has thrown an exception itselfValidationException - in case validation could not be performed for some reason (e.g. no validation information available)InvalidModelException - in case the given model type could not be validated through the model validationboolean canCreateFromAdaptable(@NotNull
@NotNull java.lang.Object adaptable,
@NotNull
@NotNull java.lang.Class<?> type)
adaptable - the adaptable to checktype - the class to checktrue in case the given class can be created from the given adaptable, otherwise false@Deprecated
boolean isModelClass(@NotNull
@NotNull java.lang.Object adaptable,
@NotNull
@NotNull java.lang.Class<?> type)
isModelClass(Class) instead!adaptable - the adaptable to checktype - the class to checkModelboolean isModelClass(@NotNull
@NotNull java.lang.Class<?> type)
Model which adapts to the given typetrue.type - the class to checktrue in case the given type can be instantiated though Sling Models.boolean isModelAvailableForResource(@NotNull
@NotNull Resource resource)
resource - a resourcetrue if a model class is mapped to the resource typeboolean isModelAvailableForRequest(@NotNull
@NotNull SlingHttpServletRequest request)
request - a requesttrue if a model class is mapped to the resource type@NotNull
@NotNull java.lang.Object getModelFromResource(@NotNull
@NotNull Resource resource)
throws MissingElementsException,
InvalidAdaptableException,
ModelClassException,
PostConstructException,
ValidationException,
InvalidModelException
resource - a resourceMissingElementsException - in case no injector was able to inject some required values with the given typesInvalidAdaptableException - in case the given class cannot be instantiated from the given adaptable (different adaptable on the model annotation)ModelClassException - in case the model could not be instantiated because model annotation was missing, reflection failed, no valid constructor was found, model was not registered as adapter factory yet, or post-construct could not be calledPostConstructException - in case the post-construct method has thrown an exception itselfValidationException - in case validation could not be performed for some reason (e.g. no validation information available)InvalidModelException - in case the given model type could not be validated through the model validation@NotNull
@NotNull java.lang.Object getModelFromRequest(@NotNull
@NotNull SlingHttpServletRequest request)
throws MissingElementsException,
InvalidAdaptableException,
ModelClassException,
PostConstructException,
ValidationException,
InvalidModelException
request - a requestMissingElementsException - in case no injector was able to inject some required values with the given typesInvalidAdaptableException - in case the given class cannot be instantiated from the given adaptable (different adaptable on the model annotation)ModelClassException - in case the model could not be instantiated because model annotation was missing, reflection failed, no valid constructor was found, model was not registered as adapter factory yet, or post-construct could not be calledPostConstructException - in case the post-construct method has thrown an exception itselfValidationException - in case validation could not be performed for some reason (e.g. no validation information available)InvalidModelException - in case the given model type could not be validated through the model validation@NotNull
<T> T exportModel(@NotNull
@NotNull java.lang.Object model,
@NotNull
@NotNull java.lang.String exporterName,
@NotNull
@NotNull java.lang.Class<T> targetClass,
@NotNull
@NotNull java.util.Map<java.lang.String,java.lang.String> options)
throws ExportException,
MissingExporterException
T - the target classmodel - the model objectexporterName - the exporter nametargetClass - the target classoptions - any exporter optionsExportException - if the export failsMissingExporterException - if the named exporter can't be found@NotNull
<T> T exportModelForResource(@NotNull
@NotNull Resource resource,
@NotNull
@NotNull java.lang.String exporterName,
@NotNull
@NotNull java.lang.Class<T> targetClass,
@NotNull
@NotNull java.util.Map<java.lang.String,java.lang.String> options)
throws MissingElementsException,
InvalidAdaptableException,
ModelClassException,
PostConstructException,
ValidationException,
InvalidModelException,
ExportException,
MissingExporterException
T - the target classresource - the resourceexporterName - the exporter nametargetClass - the target classoptions - any exporter optionsMissingElementsException - in case no injector was able to inject some required values with the given typesInvalidAdaptableException - in case the given class cannot be instantiated from the given adaptable (different adaptable on the model annotation)ModelClassException - in case the model could not be instantiated because model annotation was missing, reflection failed, no valid constructor was found, model was not registered as adapter factory yet, or post-construct could not be calledPostConstructException - in case the post-construct method has thrown an exception itselfValidationException - in case validation could not be performed for some reason (e.g. no validation information available)InvalidModelException - in case the given model type could not be validated through the model validationExportException - if the export failsMissingExporterException - if the named exporter can't be found@NotNull
<T> T exportModelForRequest(@NotNull
@NotNull SlingHttpServletRequest request,
@NotNull
@NotNull java.lang.String exporterName,
@NotNull
@NotNull java.lang.Class<T> targetClass,
@NotNull
@NotNull java.util.Map<java.lang.String,java.lang.String> options)
throws MissingElementsException,
InvalidAdaptableException,
ModelClassException,
PostConstructException,
ValidationException,
InvalidModelException,
ExportException,
MissingExporterException
T - the target classrequest - the requestexporterName - the exporter nametargetClass - the target classoptions - any exporter optionsMissingElementsException - in case no injector was able to inject some required values with the given typesInvalidAdaptableException - in case the given class cannot be instantiated from the given adaptable (different adaptable on the model annotation)ModelClassException - in case the model could not be instantiated because model annotation was missing, reflection failed, no valid constructor was found, model was not registered as adapter factory yet, or post-construct could not be calledPostConstructException - in case the post-construct method has thrown an exception itselfValidationException - in case validation could not be performed for some reason (e.g. no validation information available)InvalidModelException - in case the given model type could not be validated through the model validationExportException - if the export failsMissingExporterException - if the named exporter can't be found@Nullable
<T> T getModelFromWrappedRequest(@NotNull
@NotNull SlingHttpServletRequest request,
@NotNull
@NotNull Resource resource,
@NotNull
@NotNull java.lang.Class<T> targetClass)
T - the target adapter classrequest - the current requestresource - the resource to set as the wrapped request's resourcetargetClass - the target adapter classCopyright © 2010 - 2023 Adobe. All Rights Reserved