Atelier: crate atelier_core

This crate provides a Rust native core model for the AWS Smithy Interface Definition Language.

crates.io docs.rs

This crate is the foundation for the Atelier set of crates, and provides the following components:

  1. The model structures themselves that represents a Smithy model This is the in-memory representation shared by all Atelier crates and tools.
  2. The model builder structures that allow for a fluent and easy construction of a core model.
  3. The prelude model containing the set of shapes defined in the Smithy specification.
  4. Traits for reading/writing models in different representations.
  5. A common error module to be used by all Atelier crates.

Example

The following example demonstrates the builder interface to create a model for a simple service. The service, MessageOfTheDay has a single resource Message. The resource has an identifier for the date, but the read operation does not make the date member required and so will return the message for the current date.

```rust use ateliercore::error::ErrorSource; use ateliercore::model::builder::values::{ArrayBuilder, ObjectBuilder}; use ateliercore::model::builder::{ Builder, ListBuilder, MemberBuilder, ModelBuilder, OperationBuilder, ResourceBuilder, ServiceBuilder, ShapeTraits, SimpleShapeBuilder, StructureBuilder, TraitBuilder, }; use ateliercore::model::{Identifier, Model, ShapeID};

fn makemodel() -> Model { ModelBuilder::new(Version::V10, "example.motd") .service( ServiceBuilder::new("MessageOfTheDay", "2020-06-21") .documentation("Provides a Message of the day.") .resource("Message") .into(), ) .resource( ResourceBuilder::new("Message") .identifier("date", "Date") .read("GetMessage") .into(), ) .simpleshape( SimpleShapeBuilder::string("Date") .applytrait(traits::pattern(r"^\d\d\d\d-\d\d-\d\d$")) .into(), ) .operation( OperationBuilder::new("GetMessage") .readonly() .input("GetMessageInput") .output("GetMessageOutput") .error("BadDateValue") .into(), ) .structure( StructureBuilder::new("GetMessageInput") .member("date", "Date") .into(), ) .structure( StructureBuilder::new("GetMessageOutput") .addmember(MemberBuilder::string("message").required().into()) .into(), ) .structure( StructureBuilder::new("BadDateValue") .errorsource(ErrorSource::Client) .addmember(MemberBuilder::string("errorMessage").required().into()) .into(), ) .into() } ``` */

Runnable Examples

The example weather_builder.rs in the examples directory uses the complete example from the Smithy quick start guide. The examples directory also includes a pair of stand-alone examples, using the semantic model and builder APIs, for the message of the day service shown in the example above.

As usual these can be executed via cargo in the following manner.

bash $ cargo run --example weather_builder $ cargo run --example motd_core $ cargo run --example motd_builder

Changes

Version 0.2.3

Version 0.2.2

Version 0.2.1

Version 0.2.0

Version 0.1.5

Version 0.1.4

Version 0.1.3

Version 0.1.2

Version 0.1.1

Version 0.1.0

TODO

  1. Complete the prelude model.
  2. Complete the selector expression types
  3. More documentation
  4. More tests