Skip to content

Latest commit

 

History

History
46 lines (35 loc) · 2.76 KB

README.md

File metadata and controls

46 lines (35 loc) · 2.76 KB

License Active codecov

YAMLtecture

A lightweight CLI tool for generating outputs, including Mermaid diagrams, from YAML-defined system architectures.

Overview

YAMLtecture is an open-source CLI tool designed for application architects who need a simple yet powerful way to define and visualize system architectures. Using modular YAML files, YAMLtecture helps you map out components, their hierarchies, and interactions, all while keeping everything easy to manage in version control. It’s built to enable taking a single larger definition configuration and applying queries to filter down to a subset for different use cases. With YAMLtecture, you can transform your YAML definitions into diagrams (including Mermaid), keeping your architecture clear, version-controlled, and up-to-date.

Configuration Files

At the core of YAMLtecture are YAML configuration files that define your system architecture. These files are split into two main sections: nodes and links. The nodes section describes the individual components of your system, while the links section defines how those components interact.

nodes:
  - id: cluster
    type: Infrastructure
    attributes:
      name: "Container Hosting"
  - id: service_foo
    type: Microservice
    parent: cluster
    attributes:
      name: "Foo Service"
      language: "Java"
  - id: service_bar
    type: Microservice
    parent: cluster
    attributes:
      name: "Bar Service"
      language: "Go"

links:
  - source: service_foo
    target: service_bar
    type: "API"
    attributes:
      payload: "example"

The key concept here is that each node has a unique id. The type field is flexible and can be set to whatever suits your architecture—common examples include Microservice, Database, Queue, etc. The parent field is optional and defines hierarchical links between nodes. These links are validated to form an acyclic tree, but not every node needs to be part of the same hierarchy.

The attributes field is a dictionary of key-value pairs that can store additional metadata about a node, useful for filtering and querying.

Links tie nodes together with the source and target fields. Each link is one-way, so for a bidirectional connection, you’ll need to define two separate links. Like nodes, links have a type field to classify the interaction (e.g., API, MessageQueue), and attributes can store metadata about the link, such as protocols, payloads, or endpoints.