Skip to content

Microservice-API-Patterns/MDSL-Specification

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Microservice Domain-Specific Language (MDSL) 4.0

Build Status License

Author: Olaf Zimmermann, (c) 2018-2020. All rights reserved.

What is MDSL?

MDSL supports the API Description pattern from Microservice API Patterns (MAP) ("polyglot service design").

This is the "hello world" of cross-platform service contracting, specified in MDSL:

API description HelloWorldAPI data type SampleDTO {ID, D} endpoint type HelloWorldEndpoint exposes operation sayHello expecting payload D<string> delivering payload SampleDTO API provider HelloWorldAPIProvider1 offers HelloWorldEndpoint API client HelloWorldAPIClient1 consumes HelloWorldEndpoint 

As the example shows, the MDSL grammar defines two related specification languages:

  1. An API description language: API endpoints types (a.k.a. service contracts types) can be defined, including their operations; API client and providers of instances of these endpoint types can be specified elaborately, including Service Level Agreements (SLAs).
  2. A data contract language providing a type system for DTRs in request and response messages (which is very compact): data type SampleDTO {ID, D}.

These two languages can be used independently of each other; for instance, data contracts for operations in contract types can also be specified in JSON Schema (or XML Schema). Specifications do not have to be complete to be useful (e.g., in early stages of service design); tools will be expected to check that, use defaults, etc.

Getting Started

Language Specification

An implemented proposal of a language extension supporting queue-based messaging endpoints is AsyncMDSL.

Repository Structure

This repository contains:

If you want to contribute to MDSL, you have to clone this repo and generate the required Xtext files.

Note: Setup and build process have been improved recently to ease integration with Context Mapper. As a consequence, the project has to be imported as an existing Maven project, and an adjustment of the IDE setup is required. The readme of the main project contains detailed instructions.

Change Log

The current version of MDSL is 4.0. See change log for an evolution history; see GitHub release notes for additional update information.

A possible roadmap for langiage and tools is (subject to change at any time):

  • Integrate AsyncMDSL into this repository (and MDSL 4.0); it extends MDSL 3 at present.
  • Java binding validation and tool support
  • GraphQL Schema Language support

Context Information: MAP and Xtext

All Microservice API Patterns (MAP) are supported and integrated one way or another:

  • As grammar rules
  • As enums for roles and responsibilities
  • As stereotypes annotating representation elements

See "MAP Decorators" section of the MDSL tutorial for more information.

The MDSL grammar, to be found in src folder of the dsl-core/io.mdsl project, was originally developed with Eclipse Photon (4.8.0) and Xtext (2.14) as provided by the Eclipse Modeling Platform. MDSL makes use of the referencing feature in Xtext ('name' attribute). Future work is required to also support this technology in other IDEs (such as Visual Studio Code).

Feedback and contributions welcome!

ZIO (a.k.a. socadk)

Acknowledgements

The creation and release of MDSL 4.0 was supported by the Hasler Foundation.

Contributors (input, DevOps support, feedback):

Getting involved

We are happy to welcome new contributors who want to help improve MDSL language and tools:

  • Feel free to create issues in GitHub.
  • Submit pull requests. If you do so, we assume that you comply with this Developer Certificate of Origin.
  • Contact us to discuss collaboration and integration opportunities.

Copyright: Olaf Zimmermann, 2019-2020. All rights reserved. See license information.