MOSDL is a language that can be used to specify CCSDS Mission Operations (MO) services. It is similar to the interface definition languages of other remote procedure call systems (RPC) like Google gRPC or Apache Thrift. For a detailed description of the service description primitives refer to CCSDS 521.0-B-2 MO Message Abstraction Layer.
The standardized service description format of CCSDS MO services is an XML format described by an XML Schema. However, these XML documents can be difficult to edit, iterate and reason about. MOSDL provides an alternative to the CCSDS MO XML format. MOSDL documents can be compiled to standards-compliant XML documents using the compiler contained in this project. It is also possible to transform CCSDS MO XML documents back to MOSDL documents.
Besides transforming MO specifications from one representation to another this project can also be used for generating other artifacts from these specifications: This project ships with a generator which creates XML Schema documents for data structures contained in MO specifications. Generated XML Schema documents conform to standard CCSDS 524.3-B-1 MO-MAL Binding to HTTP Transport and XML Encoding.
MOSDL has been developed at the German Space Operations Center GSOC, which is part of DLR, the German Aerospace Center.
Current version: ${project.version} (also see change log)
- Example
- MOSDL language
- Usage
- Source code and compilation
- Contributing
- Maintainer
- Copyright, license and third party software
A very simple MOSDL document looks like this:
area TestArea [123]
service HelloWorldService {
request myOperation(hello: String)
-> (world: String)
}
The snippet above describes a service (HelloWorldService
) offering one request-response operation (myOperation
) that takes a single String parameter as request (hello
) and returns a single String parameter as response (world
).
The MOSDL compiler can be used to generate an CCSDS MO XML document, which can then be used by third-party software (e.g. ESA CCSDS MO API Generator) to generate documentation, API code for service consumers and providers, and possible other representations.
The MOSDL language is documented in the MOSDL language reference. Syntax highlighting is provided for Notepad++ users: Just load npp_mosdl.xml
in Notepad++ using its user-defined language functionality.
This project can be used in three different ways:
- as a command-line interface (CLI) program for transforming MOSDL to CCSDS MO XML files and vice versa,
- as a plugin for a Maven-based build process in order to transform MOSDL to/from CCSDS MO XML,
- as a Java library for reading and writing MOSDL and CCSDS MO XML files.
You need at least Java 11 JDK (e.g. Eclipse Temurin) if you use this project as Maven plugin or Java library. The stand-alone program should also run fine with a Java 11 JRE. Currently, LTS Java versions 11, 17 and 21 are supported.
The latest release of the MOSDL standalone CLI program is available for download on the GitHub Releases page as ZIP file.
Unzip the standalone command-line interface distribution package and invoke the compiler from the command line like:
java -jar mosdl.jar --help
This will print detailed usage instruction which are repeated here for convenience:
Compiler for MOSDL - Mission Operations Service Description Language for CCSDS MO Services (version ${project.version})
Usage: <service-descr> [<target-dir>] [-x|--xml] [-m|--mosdl] [-s|--xsd] [-b|--create-body-types] [-sv|--skip-validation] [-t|--doc-type <doc-type>] [-h|--help]
<service-descr>
MO service description file (CCSDS MO XML or MOSDL service description language) or directory containing files in MOSDL service description language.
(required)
<target-dir>
Target directory for generated files.
Default: .
-x, --xml
If given MO XML service description file will be generated.
-m, --mosdl
If given MOSDL service description file will be generated.
-s, --xsd
If given an MO data structure XML Schema file will be generated.
-b, --create-body-types
If given specialized non-standard message body XSD types will be generated for operations (only applicable when generating XML Schema files).
-sv, --skip-validation
If given try to recover from MOSDL files with errors and do not validate XML input and output files against the service schema. Useful for slightly malformed files.
-t, --doc-type <doc-type>
Type of documentation to create for MOSDL or XSD files (BULK: operation documentation will be generated in bulk; INLINE: operation documentation will be put in-line; SUPPRESS: all documentation is stripped). BULK and INLINE produce the same results for XSD files.
Possible values: BULK, INLINE, SUPPRESS
Default: BULK
-h, --help
Print detailed usage instructions for this program.
In case you need more detailed logging you can change the log settings by supplying certain system properties to the JVM. Please refer to the documentation of the slf4j-simple
logger (which is used by the command-line interface) for all possible settings. If you simply wish to activate the debug log level invoke MOSDL like:
java -Dorg.slf4j.simpleLogger.defaultLogLevel=debug -jar mosdl.jar --help
The Maven plugin is available on the Maven Central Repository. Add a build plugin dependency to your Maven pom.xml
file:
<plugin>
<groupId>${project.groupId}</groupId>
<artifactId>${project.artifactId}</artifactId>
<version>${project.version}</version>
<configuration>
<serviceSpecs>
<serviceSpec>src/main/mosdl</serviceSpec>
</serviceSpecs>
<xml>true</xml>
</configuration>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
</plugin>
Alternatively, you can download the JAR file directly or compile the plugin yourself and put the classes on your classpath.
Reference all your service description XML/MOSDL files or directories in the <serviceSpecs>
tag (multiple <serviceSpec>
tags are allowed here). It is advisable to put your service specifications in the src/main/mosdl
directory. The generated files will be put in the generated-sources/mosdl
subfolder of your target folder.
The following configuration options are available:
<serviceSpecs>
: Required. List the service specification files you wish to generate code for here. You can specify a service description XML file here, a single MOSDL file or a directory containing multiple MOSDL files that together form a single service specification.<xml>
: Optional. Set totrue
if you want to generate the service description XML files.<mosdl>
: Optional. Set totrue
if you want to generate the service description MOSDL files.<xsd>
: Optional. Set totrue
if you want to generate XSD files for data structures contained in the service descriptions.<xsdBodyTypes>
: Optional. Set totrue
if you want to generate specialized non-standard message body XSD types for operations (only applicable when generating XSD files).<skipValidation>
: Optional. Set totrue
if you want to skip validation of XML input and output files against the service schema.<docType>
: Optional, one ofBULK
(default),INLINE
orSUPPRESS
. UseBULK
to create bulk operation documentation using tags for messages, parameters and errors. UseINLINE
if you want to attach documentation directly to these elements instead of using special tags. Set toSUPPRESS
if you want to strip documentation when creating MOSDL files. Also controls documentation generation for XSD files, but there is no difference betweenBULK
andINLINE
. Has no effect if no MOSDL or XSD files are created.
The Maven plugin uses the logging functionality provided by Maven. Therefore, debug log messages can be printed by supplying the -X
switch to Maven.
The Java library is available on the Maven Central Repository. Add a dependency to your Maven pom.xml
file:
<dependency>
<groupId>${project.groupId}</groupId>
<artifactId>${project.artifactId}</artifactId>
<version>${project.version}</version>
</dependency>
Alternatively, you can download the JAR file directly or compile the library yourself and put the classes on your classpath.
Use cases for this library are loading specifications, writing specifications and other artifacts, as well as glueing loading and writing together. This document shall just give a hint where to start. Please refer to the code documentation for detailed instructions on how to use the classes provided in this project.
This library uses the SLF4J logging facade for logging. You should provide an SLF4J implementation on the classpath, otherwise an error message complaining about a missing implementation is printed and you will not see any log output.
Two SpecLoader
implementations are shipped that allow you to load a specification from MOSDL (MosdlSpecLoader
) or XML (XmlSpecLoader
).
Example:
SpecLoader specLoader = new MosdlSpecLoader(false);
specLoader.setInput(inputFileOrDirectory);
if (specLoader.isLoadable()) {
SpecificationType spec = loader.load();
}
Two Generator
implementations are shipped that allow you to write a specification to MOSDL (MosdlGenerator
) or XML (XmlGenerator
).
Example:
Generator generator = new MosdlGenerator(MosdlGenerator.DocType.BULK);
generator.generate(spec, targetDirectory);
A third Generator
implementation is shipped that allows you to write XML Schema documents for data structures contained in MO specifications (XsdGenerator
).
Example:
Generator generator = new XsdGenerator(true);
generator.generate(spec, targetDirectory);
An abstract Runner
class is provided with an execute()
method that loads a set of SpecLoader
s, tries to load a specification with one of them, loads a set of Generator
s and writes out the loaded specification using all of them. Methods createSpecLoaders()
and createGenerators()
need to be implemented by a subclass. A concrete subclass MosdlRunner
is provided that creates all of the above mentioned specification loaders and generators. If you want to include your own specification loader or generator you can subclass Runner
(or MosdlRunner
) yourself.
The source code of this project is available on GitHub: https://github.com/DLR-RB/mosdl
Use git to clone the source repository:
git clone https://github.com/DLR-RB/mosdl.git
The only requirements for compiling the project yourself are a Java 8 JDK (e.g. AdoptOpenJDK) and Maven 3. Currently, Java versions other than Java 8 are not supported.
This project uses a standard Maven-based build process. You can compile the source yourself by simply issuing
mvn install
in the project base directory. Required dependencies need to be resolved by Maven, e.g. by getting them from the Maven Central Repository. You will find the compiled packages in the target
directory as well as your local Maven repository.
Contributions to this project are welcome. You may open issues, fix or expand documentation, provide new functionality or create more and better tests. If you have a minor contribution you can open a pull request right away. For any major contribution please open an issue first or discuss with the repository maintainer. Please also note that you need to fill out and sign a contributor license agreement.
The current maintainer of MOSDL is Stefan Gärtner (@S-Gaertner).
Mission Operations Service Description Language and Compiler (MOSDL)
Copyright 2019 DLR - Deutsches Zentrum für Luft- und Raumfahrt e.V.
This product was developed at DLR - GSOC (German Space Operations Center at the German Aerospace Center DLR, https://www.dlr.de/).
MOSDL is licensed under the Apache License, Version 2.0.
The command-line interface binary distribution of MOSDL comes bundled with a number of third party software components. Please refer to THIRD-PARTY.txt for notices, licenses and additional terms and conditions of these components.