Modelina is the official AsyncAPI SDK to generate data models (i.e. Java/TypeScript classes, Go Structs, etc) from AsyncAPI documents, among other supported inputs.
π’ ATTENTION:
This package is currently being prepared to reach version 1.0.0 and the development is therefore happening on the next
branch, any features must be based and targetting that branch.
- Requirements
- Installation
- Features
- Roadmap
- Documentation
- Examples
- Development
- Contributing
- Contributors β¨
Requirements
- NodeJS >= 14
Feel free to submit an issue if you require this project in other use-cases.
Installation
Run this command to install Modelina in your project:
npm install @asyncapi/modelina
Once you've successfully installed Modelina in your project, it's time to select your generator. Check out the examples for the specific code.
Features
The following table provides a short summary of available features for supported output languages.
To see the complete feature list for each language, please click the individual links for each language.
Supported inputs | description |
---|---|
AsyncAPI | We support the following AsyncAPI versions: 2.0.0, 2.1.0, 2.2.0, 2.3.0 and 2.4.0, which generates models for all the defined message payloads. |
JSON Schema | We support the following JSON Schema versions: Draft-4, Draft-6 and Draft-7 |
OpenAPI | We support the following OpenAPI versions: Swagger 2.0 and OpenAPI 3.0, which generates models for all the defined request and response payloads. |
TypeScript file | We currently support TypeScript type file as input for model generation |
Supported outputs | Features |
---|---|
Java | Class and enum generation: generation of equals, hashCode, toString, Jackson annotation, custom indentation type and size, etc |
TypeScript | Class, interface and enum generation: generation of example code, un/marshal functions, custom indentation type and size, etc |
C# | Class and enum generation: generation of example code, serializer and deserializer functions, custom indentation type and size, etc |
Go | Struct and enum generation: custom indentation type and size, etc |
JavaScript | Class generation: custom indentation type and size, etc |
Dart | Class and enum generation: json_annotation |
Roadmap
Documentation
Documentation for this library can be found under the documentation folder.
Examples
Do you need to know how to use the library in certain scenarios?
We have gathered all the examples in a separate folder and they can be found under the examples folder.
Development
To setup your development environment please read the development document.
Contributing
Read our contributor guide.
Contributors β¨
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!