Class ModelAssembler
- java.lang.Object
-
- software.amazon.smithy.model.loader.ModelAssembler
-
public final class ModelAssembler extends java.lang.Object
Assembles and validates aModel
from documents, files, shapes, and other sources.Validation vents are aggregated into a
Set
to ensure that duplicate events are not emitted.Smithy models found on the class path can be discovered using model discovery. Model discovery must be explicitly requested of a
ModelAssembler
by invokingdiscoverModels()
ordiscoverModels(ClassLoader)
.- See Also:
Model.assembler()
-
-
Field Summary
Fields Modifier and Type Field Description static java.lang.String
ALLOW_UNKNOWN_TRAITS
Allow unknown traits rather than fail.static java.lang.String
DISABLE_JAR_CACHE
SetsURLConnection.setUseCaches(boolean)
to false.
-
Constructor Summary
Constructors Constructor Description ModelAssembler()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description ModelAssembler
addDocumentNode(Node document)
Adds a parsed JSON model file as aNode
to the assembler.ModelAssembler
addImport(java.lang.String importPath)
Adds an import to the assembler.ModelAssembler
addImport(java.net.URL url)
Adds an import to the assembler from a URL.ModelAssembler
addImport(java.nio.file.Path importPath)
Adds an import to the assembler.ModelAssembler
addModel(Model model)
Merges a loaded model into the model assembler.ModelAssembler
addShape(Shape shape)
Explicitly injects a shape into the assembled model.ModelAssembler
addShapes(Shape... shapes)
Explicitly injects multiple shapes into the assembled model.ModelAssembler
addTrait(ShapeId target, Trait trait)
Explicitly adds a trait to a shape in the assembled model.ModelAssembler
addUnparsedModel(java.lang.String sourceLocation, java.lang.String model)
Adds a string containing an unparsed model to the assembler.ModelAssembler
addValidator(Validator validator)
Registers a validator to be used when validating the model.ValidatedResult<Model>
assemble()
Assembles the model and returns the validated result.ModelAssembler
copy()
Creates a copy of the current model assembler.ModelAssembler
disablePrelude()
Disables automatically loading the prelude models.ModelAssembler
disableValidation()
Disables additional validation of the model.ModelAssembler
discoverModels()
Discovers models by merging in all models returns byModelDiscovery
manifests using the thread contextClassLoader
.ModelAssembler
discoverModels(java.lang.ClassLoader loader)
Discovers models by merging in all models returns byModelDiscovery
manifests using the providedClassLoader
.ModelAssembler
putMetadata(java.lang.String name, Node value)
Adds metadata to the model.ModelAssembler
putProperty(java.lang.String setting, java.lang.Object value)
Puts a configuration property on the ModelAssembler.ModelAssembler
removeProperty(java.lang.String setting)
Removes a setting from the ModelAssembler.ModelAssembler
reset()
Resets the state of the ModelAssembler.ModelAssembler
traitFactory(TraitFactory traitFactory)
Uses a customTraitFactory
to resolve and configure traits.ModelAssembler
validatorFactory(ValidatorFactory validatorFactory)
Sets a customValidatorFactory
used to dynamically resolve validator definitions.
-
-
-
Field Detail
-
ALLOW_UNKNOWN_TRAITS
public static final java.lang.String ALLOW_UNKNOWN_TRAITS
Allow unknown traits rather than fail.- See Also:
- Constant Field Values
-
DISABLE_JAR_CACHE
public static final java.lang.String DISABLE_JAR_CACHE
SetsURLConnection.setUseCaches(boolean)
to false.When running in a build environment, using caches can cause exceptions like `java.util.zip.ZipException: ZipFile invalid LOC header (bad signature)` because a previously loaded JAR might change between builds. The "assembler.disableJarCache" setting should be set to true when embedding Smithy into an environment where this can occur.
- See Also:
- Constant Field Values
-
-
Method Detail
-
copy
public ModelAssembler copy()
Creates a copy of the current model assembler.- Returns:
- Returns the created model assembler copy.
-
reset
public ModelAssembler reset()
Resets the state of the ModelAssembler.The following properties of the ModelAssembler are cleared when this method is called:
- Validators registered via
addValidator(software.amazon.smithy.model.validation.Validator)
- Models registered via
addImport(java.lang.String)
- Models registered via
addDocumentNode(software.amazon.smithy.model.node.Node)
- Models registered via
addUnparsedModel(java.lang.String, java.lang.String)
- Models registered via
addModel(software.amazon.smithy.model.Model)
- Shape registered via
addModel(software.amazon.smithy.model.Model)
- Metadata registered via
putMetadata(java.lang.String, software.amazon.smithy.model.node.Node)
- Validation is re-enabled if it was disabled.
The state of
disablePrelude
is reset such that the prelude is no longer disabled after callingreset
.- Returns:
- Returns the model assembler.
- Validators registered via
-
traitFactory
public ModelAssembler traitFactory(TraitFactory traitFactory)
Uses a customTraitFactory
to resolve and configure traits.- Parameters:
traitFactory
- Trait factory to use instead of the default.- Returns:
- Returns the assembler.
-
validatorFactory
public ModelAssembler validatorFactory(ValidatorFactory validatorFactory)
Sets a customValidatorFactory
used to dynamically resolve validator definitions.Note that if you do not provide an explicit validatorFactory, a default factory is utilized that uses service discovery.
- Parameters:
validatorFactory
- Validator factory to use.- Returns:
- Returns the assembler.
-
addValidator
public ModelAssembler addValidator(Validator validator)
Registers a validator to be used when validating the model.- Parameters:
validator
- Validator to register.- Returns:
- Returns the assembler.
-
addUnparsedModel
public ModelAssembler addUnparsedModel(java.lang.String sourceLocation, java.lang.String model)
Adds a string containing an unparsed model to the assembler.The provided
sourceLocation
string must end with ".json" or ".smithy" to be parsed correctly.- Parameters:
sourceLocation
- Source location to assume for the unparsed content.model
- Unparsed model source.- Returns:
- Returns the assembler.
-
addDocumentNode
public ModelAssembler addDocumentNode(Node document)
Adds a parsed JSON model file as aNode
to the assembler.- Parameters:
document
- Parsed document node to add.- Returns:
- Returns the assembler.
-
addImport
public ModelAssembler addImport(java.lang.String importPath)
Adds an import to the assembler.- Parameters:
importPath
- Import path to add.- Returns:
- Returns the assembler.
- See Also:
addImport(Path)
-
addImport
public ModelAssembler addImport(java.nio.file.Path importPath)
Adds an import to the assembler.If a directory is found, all ".json" and ".ion" files that contain a "smithy" key-value pair found in the directory and any subdirectories are imported into the model.
- Parameters:
importPath
- Import path to add.- Returns:
- Returns the assembler.
-
addImport
public ModelAssembler addImport(java.net.URL url)
Adds an import to the assembler from a URL.The provided URL can point to a .json model, .smithy model, or a .jar file that contains Smithy models.
Model model = Model.assembler() .addImport(getClass().getClassLoader().getResource("model.json")) .assemble() .unwrap();
- Parameters:
url
- Resource URL to load and add.- Returns:
- Returns the assembler.
-
disablePrelude
public ModelAssembler disablePrelude()
Disables automatically loading the prelude models.- Returns:
- Returns the assembler.
-
addShape
public ModelAssembler addShape(Shape shape)
Explicitly injects a shape into the assembled model.- Parameters:
shape
- Shape to add.- Returns:
- Returns the assembler.
-
addShapes
public ModelAssembler addShapes(Shape... shapes)
Explicitly injects multiple shapes into the assembled model.- Parameters:
shapes
- Shapes to add.- Returns:
- Returns the assembler.
-
addTrait
public ModelAssembler addTrait(ShapeId target, Trait trait)
Explicitly adds a trait to a shape in the assembled model.- Parameters:
target
- Shape to add the trait to.trait
- Trait to add.- Returns:
- Returns the assembler.
-
addModel
public ModelAssembler addModel(Model model)
Merges a loaded model into the model assembler.- Parameters:
model
- Model to merge in.- Returns:
- Returns the model assembler.
-
putMetadata
public ModelAssembler putMetadata(java.lang.String name, Node value)
Adds metadata to the model.- Parameters:
name
- Metadata key to set.value
- Metadata value to set.- Returns:
- Returns the model assembler.
-
discoverModels
public ModelAssembler discoverModels(java.lang.ClassLoader loader)
Discovers models by merging in all models returns byModelDiscovery
manifests using the providedClassLoader
.- Parameters:
loader
- Class loader to use to discover models.- Returns:
- Returns the model assembler.
-
discoverModels
public ModelAssembler discoverModels()
Discovers models by merging in all models returns byModelDiscovery
manifests using the thread contextClassLoader
.- Returns:
- Returns the model assembler.
-
putProperty
public ModelAssembler putProperty(java.lang.String setting, java.lang.Object value)
Puts a configuration property on the ModelAssembler.Any number of properties can be given to the model assembler to affect how models are loaded. Some properties like
ALLOW_UNKNOWN_TRAITS
are built-in properties, while other properties can be custom properties that are specific to certainModelLoader
implementations.The following example configures the ModelAssembler to emit warnings for unknown traits rather than fail:
ModelAssembler assembler = Model.assembler(); assembler.putProperty(ModelAssembler.ALLOW_UNKNOWN_TRAITS, true);
- Parameters:
setting
- Name of the property to put.value
- Value to set for the property.- Returns:
- Returns the assembler.
-
removeProperty
public ModelAssembler removeProperty(java.lang.String setting)
Removes a setting from the ModelAssembler.- Parameters:
setting
- Setting to remove.- Returns:
- Returns the assembler.
-
disableValidation
public ModelAssembler disableValidation()
Disables additional validation of the model.- Returns:
- Returns the assembler.
-
assemble
public ValidatedResult<Model> assemble()
Assembles the model and returns the validated result.Implementation notes
Assembling models is a multi-step process that revolves around
ModelFile
s. ModelFiles are essentially files that contain localized definitions of shapes and metadata. Some model files use forward references and can't be fully resolved until all other model files have been loaded. To achieve this, the assembler first creates a model file that represents manually added shapes, traits, validators, etc., and then parses each given import. Parsing an import is used to create zero or more ModelFiles by parsing .json, .smithy, and .jar files.After the parsing phase, each model file returns the metadata defined in the file using
ModelFile.metadata()
and the set of shape IDs that were defined in the file usingModelFile.shapeIds()
. The metadata across each file is merged together using the rules defined in the Smithy specification.Next, the assembler calls
ModelFile.resolveShapes(java.util.Set<software.amazon.smithy.model.shapes.ShapeId>, java.util.function.Function<software.amazon.smithy.model.shapes.ShapeId, software.amazon.smithy.model.shapes.ShapeType>)
on each ModelFile which resolves any forward references, creates traits, and returns all of the traits created in the file. The assembler passes in the set of found shapes IDs along with a function that can be used to get theShapeType
of any defined shape (this is used to coerce annotation trait values into the appropriate type for a trait). The assembler aggregates and merges the traits applied across all model files using the merge rules defined in the Smithy specification.Next, the assembler invokes
ModelFile.createShapes(software.amazon.smithy.model.loader.TraitContainer)
, passing in all of the traits defined across every model file. This method causes a ModelFile to apply these traits to any shape in the ModelFile, build each shape, and return the built shapes. The assembler then aggregates all of the created traits, performs conflict resolution, and builds aModel
from the shapes and loaded metadata. A shape is allowed to be defined in multiple model files if the conflicting shapes are equivalent after all traits have been applied to both shapes.- Returns:
- Returns the validated result that optionally contains a Model and validation events.
-
-