Skip to content

Latest commit

 

History

History
287 lines (189 loc) · 14.8 KB

README.md

File metadata and controls

287 lines (189 loc) · 14.8 KB

MOSDL - Mission Operations Service Description Language

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)

Table of contents

Example

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.

MOSDL language

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.

Usage

This project can be used in three different ways:

  1. as a command-line interface (CLI) program for transforming MOSDL to CCSDS MO XML files and vice versa,
  2. as a plugin for a Maven-based build process in order to transform MOSDL to/from CCSDS MO XML,
  3. 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.

Stand-alone usage

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

Usage as plugin in a Maven-based build process

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 to true if you want to generate the service description XML files.
  • <mosdl>: Optional. Set to true if you want to generate the service description MOSDL files.
  • <xsd>: Optional. Set to true if you want to generate XSD files for data structures contained in the service descriptions.
  • <xsdBodyTypes>: Optional. Set to true if you want to generate specialized non-standard message body XSD types for operations (only applicable when generating XSD files).
  • <skipValidation>: Optional. Set to true if you want to skip validation of XML input and output files against the service schema.
  • <docType>: Optional, one of BULK (default), INLINE or SUPPRESS. UseBULK to create bulk operation documentation using tags for messages, parameters and errors. Use INLINE if you want to attach documentation directly to these elements instead of using special tags. Set to SUPPRESS if you want to strip documentation when creating MOSDL files. Also controls documentation generation for XSD files, but there is no difference between BULK and INLINE. 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.

Usage as a Java library

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.

Load a specification

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();
}

Write a specification

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);

Write other artifacts

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);

Glueing together loading and writing of a specification

An abstract Runner class is provided with an execute() method that loads a set of SpecLoaders, tries to load a specification with one of them, loads a set of Generators 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.

Source code and compilation

Source code

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

Compilation

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.

Contributing

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.

Maintainer

The current maintainer of MOSDL is Stefan Gärtner (@S-Gaertner).

Copyright, license and third party software

Copyright

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/).

License

MOSDL is licensed under the Apache License, Version 2.0.

Third party software in binary distributions

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.