cgardner / dsl

Structurizr DSL

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Structurizr

Structurizr DSL

This GitHub repository contains an implementation of the Structurizr DSL - a way to create Structurizr software architecture models based upon the C4 model using a textual domain specific language (DSL). This repository is supported by Structurizr Limited, as a part of the Structurizr service.

A quick example

As an example, the following text can be used to create a software architecture model and an associated view that describes a user using a software system.

workspace "Getting Started" "This is a model of my software system." {

    model {
        user = person "User" "A user of my software system."
        softwareSystem = softwareSystem "Software System" "My software system."

        user -> softwareSystem "Uses"
    }

    views {
        systemContext softwareSystem "SystemContext" "An example of a System Context diagram." {
            include *
            autoLayout
        }

        styles {
            element "Software System" {
                background #1168bd
                color #ffffff
            }
            element "Person" {
                shape person
                background #08427b
                color #ffffff
            }
        }
    }
    
}

(view this example)

Multiple output formats

The view can then be exported to be visualised using the Structurizr cloud service/on-premises installation, or other formats including PlantUML, Mermaid, and WebSequenceDiagrams via the Structurizr CLI.

Multiple output formats: Structurizr, Mermaid, PlantUML

See Structurizr - Text as an architecture description language for more details.

Convention over configuration, useful defaults

The DSL is designed to be as compact as possible. In conjunction with the Structurizr CLI, the following DSL fragment will automatically create the implied relationship between the user and softwareSystem elements, create three views with auto-layout enabled (1 x System Landscape, 1 x System Context, 1 x Container), and add some default element styles.

workspace {

    model {
        user = person "User"
        softwareSystem = softwareSystem "Software System" {
            webapp = container "Web Application"
            database = container "Database"
         }

        user -> webapp "Uses"
        webapp -> database "Reads from and writes to"
    }

}

(view this example)

Table of contents

About

Structurizr DSL

License:Apache License 2.0


Languages

Language:Java 100.0%