Ember Schema Generator

Generates an Ember schema from a Jackson model.

Лицензия

Лицензия

Группа

Группа

com.github.marcus-nl
Идентификатор

Идентификатор

ember-schema-generator
Последняя версия

Последняя версия

1.0.2
Дата

Дата

Тип

Тип

jar
Описание

Описание

Ember Schema Generator
Generates an Ember schema from a Jackson model.
Ссылка на сайт

Ссылка на сайт

https://github.com/marcus-nl/ember-schema-generator
Система контроля версий

Система контроля версий

https://github.com/marcus-nl/ember-schema-generator

Скачать ember-schema-generator

Как подключить последнюю версию

<!-- https://jarcasting.com/artifacts/com.github.marcus-nl/ember-schema-generator/ -->
<dependency>
    <groupId>com.github.marcus-nl</groupId>
    <artifactId>ember-schema-generator</artifactId>
    <version>1.0.2</version>
</dependency>
// https://jarcasting.com/artifacts/com.github.marcus-nl/ember-schema-generator/
implementation 'com.github.marcus-nl:ember-schema-generator:1.0.2'
// https://jarcasting.com/artifacts/com.github.marcus-nl/ember-schema-generator/
implementation ("com.github.marcus-nl:ember-schema-generator:1.0.2")
'com.github.marcus-nl:ember-schema-generator:jar:1.0.2'
<dependency org="com.github.marcus-nl" name="ember-schema-generator" rev="1.0.2">
  <artifact name="ember-schema-generator" type="jar" />
</dependency>
@Grapes(
@Grab(group='com.github.marcus-nl', module='ember-schema-generator', version='1.0.2')
)
libraryDependencies += "com.github.marcus-nl" % "ember-schema-generator" % "1.0.2"
[com.github.marcus-nl/ember-schema-generator "1.0.2"]

Зависимости

compile (2)

Идентификатор библиотеки Тип Версия
com.fasterxml.jackson.core : jackson-databind jar 2.4.2
com.google.guava : guava jar 15.0

test (3)

Идентификатор библиотеки Тип Версия
junit : junit jar 4.11
org.assertj : assertj-core jar 1.6.1
org.assertj : assertj-guava jar 1.2.0

Модули Проекта

Данный проект не имеет модулей.

Ember Schema Generator

Ember Schema Generator can be used to generate an Ember schema from a Jackson model. This makes integration between Java and Ember much easier, because you only need to define your data model once, avoiding code duplication.

For our purpuses, a Jackson model is the set of classes that are mapped by Jackson Databind. The mapping can be configured in any way supported by Jackson Databind, usually through Jackson Annotations.

The generated Ember schema is a declarative JSON representation of the mapped classes and their properties. The classes have an optional super type. Each property has a name and a declared type.

To use the schema on the client side load it by using Ember Schema Loader.

License

Apache 2.0: http://www.apache.org/licenses/LICENSE-2.0

Maven

<dependency>
	<groupId>com.github.marcus-nl</groupId>
	<artifactId>ember-schema-generator</artifactId>
	<version>1.0.2</version>
</dependency>

JavaDoc

http://marcus-nl.github.io/ember-schema-generator/

Usage

Create an instance of EmberSchemaGenerator by passing your Jackson ObjectMapper to its constructor. Then register the classes and hierarchies you want included in the model by calling addClass and addHierarchy respectively. Those classes will be processed by inspecting all properties that are known to the ObjectMapper. All classes that were encountered by inspecting those properties will also be processed.

The generator will respect the property filters of the object mapper, so that only those properties that are included by the filters will end up in the schema.

Note that addHierarchy will only add those classes that are known by the object mapper, either through ObjectMapper#registerSubtypes or by using the @JsonSubTypes annotation on the base type.

Example

Given the following data model:

Zoo UML

An EmberSchema can be generated as follows:

ObjectMapper objectMapper = ...;
EmberSchemaGenerator generator = new EmberSchemaGenerator(objectMapper);

generator.addClass(Zoo.class);
generator.addHierarchy(Animal.class);

EmberSchema schema = generator.getEmberSchema();

The EmberSchema can then be converted to JSON in the usual way (example), which will look like this:

{
  "classes" : [ {
    "name" : "Zoo",
    "superType" : null,
    "props" : [ {
      "name" : "name",
      "type" : { "kind" : "attr", "name" : "string" }
    }, {
      "name" : "city",
      "type" : { "kind" : "attr", "name" : "string" }
    }, {
      "name" : "star",
      "type" : { "kind" : "one", "name" : "Animal" }
    }, {
      "name" : "animals",
      "type" : { "kind" : "many", "name" : "Animal" }
    } ]
  }, {
    "name" : "Animal",
    "superType" : null,
    "props" : [ {
      "name" : "name",
      "type" : { "kind" : "attr", "name" : "string" }
    }, {
      "name" : "type",
      "type" : { "kind" : "attr", "name" : "string" }
    } ]
  }, {
    "name" : "Elephant",
    "superType" : "Animal",
    "props" : [ {
      "name" : "trunkLength",
      "type" : { "kind" : "attr", "name" : "number" }
    } ]
  }, {
    "name" : "Lion",
    "superType" : "Animal",
    "props" : [ {
      "name" : "hasManes",
      "type" : { "kind" : "attr", "name" : "boolean" }
    } ]
  } ]
}

Версии библиотеки

Версия
1.0.2
1.0.1
1.0.0