Getting started with visualizations
Visualizations provide a unique way of looking at the data generated by specific recipes. A visualization could be a complex image that you can zoom in and out of to examine connections between nodes or it could be as simple as a text-based table that you can filter or search (see the examples section to see what these look like).
In this guide, we will explain everything you need to know to find, use, and create visualizations in the Moderne Platform.
Where visualizations exist
While you will see a visualization button on every recipe run, it will be disabled for most recipes.
This is because only a handful of recipes currently offer visualizations. You can see the list of visualizations in the moderne-visualizations-misc repository or you can use the following GraphQL query to find all visualizations:
query {
visualizationCategories {
visualizations {
id
name
description
recipe {
id
}
}
}
}
Below you can find some of the most popular recipes that currently produce visualizations:
org.openrewrite.sql.FindSql
org.openrewrite.java.dependencies.DependencyVulnerabilityCheck
org.openrewrite.cobol.search.FindRelationships
org.openrewrite.gradle.search.FindGradleWrapper
org.openrewrite.cobol.search.FindCopybook
org.openrewrite.cobol.search.FindRelationships
org.openrewrite.FindSourceFiles
org.openrewrite.LanguageComposition
org.openrewrite.FindLstProvenance
org.openrewrite.LanguageComposition
org.openrewrite.java.search.FindMethods
How to view visualizations
If a recipe produces a visualization, you can find them in the Visualizations
tab:
data:image/s3,"s3://crabby-images/773bd/773bdebaca3d2bf35de50ef5cd7c964e0f713866" alt="Visualizations button"
The visualizations page will often include multiple visualizations. Find the one you want to run and, if it has options to fill out, fill them in as needed.
Visualization options serve two main purposes: they can change the rendering of the visualization (such as turning a node from a square to a circle) or they can subset the data (e.g., taking 1000 nodes and filtering them down to 100 that match your specific needs).
data:image/s3,"s3://crabby-images/d204b/d204b64edd0e19cfeb3f7095112b441f08eda838" alt="Visualizations list"
Once you've selected the options you want, click the Run Visualization
button at the bottom:
data:image/s3,"s3://crabby-images/e82d5/e82d58b8efbdb4e52fbce6ab939e5af5755ed74b" alt="Run visualization"
This will trigger the process for building the visualization. Once it's done building, you should see a visualization appear:
data:image/s3,"s3://crabby-images/23095/23095c38b8f741704363287099ffc0fe2ab4be24" alt="Visualization result"
How to create visualizations
Please see our how to create visualizations guide.
Visualization examples
Language composition report
This reports the usage of different programming languages and data file formats. Can be configured to count lines of text or number of files.
data:image/s3,"s3://crabby-images/8cff6/8cff661ce065ce7c781843dceb694d9823d234e2" alt="Language composition"
SQL operation usage in code
Reports SQL operation usage. A good way to understand the SQL usage patterns and identify programs which interact with a database.
data:image/s3,"s3://crabby-images/e4e85/e4e85520c200fc149b59c35542070823aa35baa5" alt="SQL operation usage"
Dependency vulnerability profile
Reports the known vulnerabilities and the related dependencies, broken down by the severity of the vulnerability. Notes whether a major, minor, or patch version increase would be sufficient to move the affected dependency to a version known to have a fix for the vulnerability.
data:image/s3,"s3://crabby-images/c6a4e/c6a4e1b6272cf34428401c94ed224d5da614dd00" alt="Dependency vulnerability profile"
Gradle wrapper composition
Reports the distribution of Gradle wrapper versions in use. Useful when planning migrations and upgrades.
data:image/s3,"s3://crabby-images/8a7d4/8a7d466363d974c919d96a4043d1171835431088" alt="Gradle wrapper composition"
Plugin versions used to build LSTs
Reports the tool which produced the LST and the version of that tool. Useful for evaluating whether or not you can expect to see the latest features and bug fixes in action.
data:image/s3,"s3://crabby-images/b1fa6/b1fa694202026e9ba1975c5611c7b3846c003f1e" alt="Plugin versions used to build LSTs"
Find uses of method in code
Reports method invocations. Useful for finding example usage or conducting impact analysis for proposed changes.
data:image/s3,"s3://crabby-images/0d581/0d5816879fcf8c53c68848ff2cf179c5baa1fa64" alt="Find uses of method in code"
COBOL relationship diagram
Reports the relationships between different COBOL resources. Includes COBOL sources, Copybooks, Link-edit cards, DB2 access, and others.
data:image/s3,"s3://crabby-images/37346/37346c8b15fb2e30bbbd110457b81c47fec73a16" alt="COBOL relationship diagram"
COBOL relationship data grid
Reports the relationships between different COBOL resources. Includes COBOL sources, Copybooks, Link-edit cards, DB2 access, and others.
data:image/s3,"s3://crabby-images/143ef/143ef428c4ca9d0b22465cca4ab55c07f6f11183" alt="COBOL relationship data grid"