Skip to main content

Moderne CLI reference

Table of contents

mod

Automated code remediation.

Usage

mod [subcommands]

Options

NameDescription
--versionDisplay version info.

Subcommands

  • afterburner: (INCUBATING) Indexes built LSTs to accelerate recipe execution.
  • audit: (INCUBATING) Perform an audit of recent activity.
  • build: Generates LST artifacts for one or more repositories.
  • clean: Clean build and run artifacts produced by the CLI.
  • config: Global configuration options that are required by some CLI commands.
  • devcenter: DevCenter operations.
  • exec: Execute an arbitrary shell command recursively on selected repository roots.
  • git: Multi-repository git operations.
  • log: Manages a log aggregate.
  • list: Lists the repositories that can be built and published.
  • monitor: (INCUBATING) Launches an HTTP server used to monitor the CLI.
  • publish: Publishes the LST artifacts for one or more projects.
  • run: Runs an OpenRewrite recipe locally on pre-built LSTS.
  • run-history: Get information about the most recent recipe runs. This will be transitioning to mod audit runs list eventually. A deprecation notice will be added here when we suggest adopting the alternative.
  • study: Produces studies from OpenRewrite recipe data tables locally.
  • generate-completion

mod afterburner

(INCUBATING) Indexes built LSTs to accelerate recipe execution.

This command indexes certain parts of the LST in order to speed up repeated recipe runs against the same LST. While not all recipes can benefit from this optimization, common ones — especially those frequently used in IDE integrations — often will.

Note: The generated indexes are internal to the CLI and may change between versions. They are intended solely for use by the CLI in subsequent run commands.

Usage

mod afterburner [parameters]

Examples

mod afterburner /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod audit

(INCUBATING) Perform an audit of recent activity.

Sources information from the activity log kept locally to provide reports in various forms.

Usage

mod audit [subcommands]

Subcommands

  • builds: (INCUBATING) Perform an audit of recent build activity.
  • runs: (INCUBATING) Perform an audit of recent recipe running activity.

mod audit builds

(INCUBATING) Perform an audit of recent build activity.

Sources information from the activity log kept locally to provide reports on LST building activity.

Usage

mod audit builds [subcommands]

Subcommands

  • list: (INCUBATING) Prints build activity to standard output.

mod audit builds list

(INCUBATING) Prints build activity to standard output.

Provides a form of build activity that can be directly consumed by reading standard output.

Usage

mod audit builds list [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--streaming(INCUBATING) Stream results from the audit to the console as they are produced. This is intended to be machine readable for the creation of incremental experiences like usage search in the IDE.

mod audit runs

(INCUBATING) Perform an audit of recent recipe running activity.

Sources information from the activity log kept locally to provide reports on recipe running activity.

Usage

mod audit runs [subcommands]

Subcommands

  • list: (INCUBATING) Prints recipe run activity to standard output.

mod audit runs list

(INCUBATING) Prints recipe run activity to standard output.

Provides a form of recipe run activity that can be directly consumed by reading standard output.

Usage

mod audit runs list [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--streaming(INCUBATING) Stream results from the audit to the console as they are produced. This is intended to be machine readable for the creation of incremental experiences like usage search in the IDE.

mod build

Generates LST artifacts for one or more repositories.

Once generated, the artifacts can be uploaded to your artifact management tool so that Moderne can ingest them or they can be used to run recipes locally.

While it is possible to manually build and publish your artifacts, we strongly recommend automating this. Please see the moderneinc/mass-ingest-example repository on GitHub for an idea of how to do that.

If the path itself is not a Git repository, then this command will recursively look through the directories to find Git repositories that match the repository-* options.

If this command executes successfully, the LST artifact for each project will be stored in a .moderne/build directory inside of each repository that is built.

If you've set up a connection with Moderne (by running the mod config moderne command), this command will attempt to download LST artifacts from Moderne instead of building them locally. This will allow you to quickly run recipes and make changes. If you do not want this command to look for LST artifacts in Moderne, you can add the --no-download flag.

Usage

mod build [parameters]

Examples

mod build /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--download-onlyOnly download LSTs from Moderne. If no download is available, do not build the LST from source.
--dry-runDo not actually build the LST(s), but list the steps that would be required to do so.
--no-downloadDo not attempt to download LSTs from Moderne.
--offlineWhen an underlying build tool has an offline mode, enable it.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--streaming(INCUBATING) Stream results from the build to the console as they are produced. This is intended to be machine readable for the creation of incremental experiences like in the IDE.

mod clean

Clean build and run artifacts produced by the CLI.

Can be filtered to only clean certain artifacts.

Usage

mod clean [subcommands]

Examples

mod clean builds /path/to/project --keep 1

Subcommands

  • builds: Clean build artifacts produced by the CLI.
  • runs: Clean run artifacts produced by the CLI.

mod clean builds

Clean build artifacts produced by the CLI.

Can be filtered to only clean certain artifacts.

Usage

mod clean builds [parameters]

Examples

mod clean builds /path/to/project --keep 1

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--keepKeep this many run artifacts and clean all others.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod clean runs

Clean run artifacts produced by the CLI.

Can be filtered to only clean certain artifacts.

Usage

mod clean runs [parameters]

Examples

mod clean runs /path/to/project --keep 1

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--keepKeep this many run artifacts and clean all others.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod config

Global configuration options that are required by some CLI commands.

Configuration set here is used as needed in all subsequent commands.

Usage

mod config [subcommands]

Examples

mod config moderne edit --api <tenant-api-gateway> --token <token>

Subcommands

  • build: Configures build tools used to produce LSTs.
  • clone: Configures cloning behavior.
  • dotnet: Configures DotNet options used for building LSTs and running recipes.
  • environment: The build environment that the CLI is running in.
  • features: Configures experimental features.
  • http: Configures HTTP options that will be used throughout the CLI.
  • java: Configures Java options used for building LSTs and running recipes.
  • license: Configure a license key.
  • lsts: Configures LSTs production and publishing.
  • moderne: Configures the connection to Moderne. Must be configured before you can install and run recipes.
  • recipes: Configures the recipe marketplace available to the CLI. Must be configured before you can run recipes.
  • run: Configures recipe run behavior.
  • scm: Configures source code management.
  • user: Configure the active user.

mod config build

Configures build tools used to produce LSTs.

Usage

mod config build [subcommands]

Subcommands

  • active-styles: Configure the active styles to use when building LSTs.
  • bazel: Configures Bazel as it is used for LST production.
  • dotnet: Configures dotnet as it is used for LST production.
  • gradle: Configures Gradle as it is used to resolve recipe dependencies and when running recipes.
  • maven: Configures Maven as it is used for LST production, resolving recipe dependencies, and when running recipes.

mod config build active-styles

Configure the active styles to use when building LSTs.

Overriding active styles circumvents auto-detection of styles in the production of LSTs.

Usage

mod config build active-styles [subcommands]

Subcommands

  • delete: Removes overriding active styles.
  • edit: Configure the active styles to use when building LSTs.
  • show: Displays the configured overriding active styles.

mod config build active-styles delete

Removes overriding active styles.

Usage

mod config build active-styles delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build active-styles edit

Configure the active styles to use when building LSTs.

Overriding active styles circumvents auto-detection of styles in the production of LSTs.

Usage

mod config build active-styles edit [parameters]

Parameters

NameDescription
activeStylesAdditional build arguments that are added to the end of the Gradle command line.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build active-styles show

Displays the configured overriding active styles.

Usage

mod config build active-styles show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel

Configures Bazel as it is used for LST production.

Usage

mod config build bazel [subcommands]

Subcommands

  • arguments: Configure Bazel build arguments.
  • executable: Configure Bazel executable.
  • timeout: Configure the build timeout.

mod config build bazel arguments

Configure Bazel build arguments.

Build arguments are added to the end of the Bazel command line when building LSTs.

Usage

mod config build bazel arguments [subcommands]

Subcommands

  • delete: Removes additional build arguments for Bazel.
  • edit: Configure Bazel build arguments.
  • show: Displays the configured Bazel additional build arguments.

mod config build bazel arguments delete

Removes additional build arguments for Bazel.

Usage

mod config build bazel arguments delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel arguments edit

Configure Bazel build arguments.

Build arguments are added to the end of the Bazel command line when building LSTs.

Usage

mod config build bazel arguments edit

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel arguments show

Displays the configured Bazel additional build arguments.

Usage

mod config build bazel arguments show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel executable

Configure Bazel executable.

Allows you to specify the location of a Bazel settings.xml file that should be used when Bazel is being used to resolve recipe dependencies or run recipes. You can also use an environment variable that points to location of the file with ${ENV_VAR} syntax.

Usage

mod config build bazel executable [subcommands]

Subcommands

  • delete: Removes the configured Bazel executable.
  • edit: Configure the Bazel executable.
  • show: Displays the configured Bazel executable.

mod config build bazel executable delete

Removes the configured Bazel executable.

The CLI will revert to its default mode of detecting the Bazel executable.

Usage

mod config build bazel executable delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel executable edit

Configure the Bazel executable.

Determines whether bazelisk or bazel will be used.

Usage

mod config build bazel executable edit [parameters]

Parameters

NameDescription
executableThe bazel executable to use. This can be just bazelisk or bazel if either is on PATH or a fully qualified executable name if not.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel executable show

Displays the configured Bazel executable.

Usage

mod config build bazel executable show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel timeout

Configure the build timeout.

Limits the amount of time the CLI will wait for a single execution of the build tool.

Usage

mod config build bazel timeout [subcommands]

Subcommands

  • delete: Removes the configured build timeout.
  • edit: Configure the timeout for build operations.
  • show: Displays the configured build timeout.

mod config build bazel timeout delete

Removes the configured build timeout.

Usage

mod config build bazel timeout delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel timeout edit

Configure the timeout for build operations.

Limits the amount of time the CLI will wait for a single execution of the build tool. Setting this to too high of a value may cause mass ingestion to hang or appear to hang.

Usage

mod config build bazel timeout edit [parameters]

Parameters

NameDescription
durationThe duration of the timeout expressed as an ISO-8601 duration. For example: 'PT1H' for one hour, 'PT30M' for 30 minutes, 'PT1H30M' for one hour and 30 minutes.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build bazel timeout show

Displays the configured build timeout.

Usage

mod config build bazel timeout show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build dotnet

Configures dotnet as it is used for LST production.

Usage

mod config build dotnet [subcommands]

Subcommands

  • timeout: Configure the build timeout.

mod config build dotnet timeout

Configure the build timeout.

Limits the amount of time the CLI will wait for a single execution of the build tool.

Usage

mod config build dotnet timeout [subcommands]

Subcommands

  • delete: Removes the configured build timeout.
  • edit: Configure the timeout for build operations.
  • show: Displays the configured build timeout.

mod config build dotnet timeout delete

Removes the configured build timeout.

Usage

mod config build dotnet timeout delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build dotnet timeout edit

Configure the timeout for build operations.

Limits the amount of time the CLI will wait for a single execution of the build tool. Setting this to too high of a value may cause mass ingestion to hang or appear to hang.

Usage

mod config build dotnet timeout edit [parameters]

Parameters

NameDescription
durationThe duration of the timeout expressed as an ISO-8601 duration. For example: 'PT1H' for one hour, 'PT30M' for 30 minutes, 'PT1H30M' for one hour and 30 minutes.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build dotnet timeout show

Displays the configured build timeout.

Usage

mod config build dotnet timeout show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle

Configures Gradle as it is used to resolve recipe dependencies and when running recipes.

Usage

mod config build gradle [subcommands]

Examples

mod config build gradle arguments edit --refresh-dependencies

Subcommands

  • arguments: Configure Gradle build arguments.
  • root: (DEPRECATED) Configure the directory containing the Gradle root build. This could be . to force the CLI to use the root directory of the repository as the Gradle build and look no deeper.
  • timeout: Configure the build timeout.

mod config build gradle arguments

Configure Gradle build arguments.

Build arguments are added to the end of the Gradle command line when building LSTs.

Usage

mod config build gradle arguments [subcommands]

Subcommands

  • delete: Removes additional build arguments for Gradle.
  • edit: Configure Gradle build arguments.
  • show: Displays the configured Gradle additional build arguments.

mod config build gradle arguments delete

Removes additional build arguments for Gradle.

Usage

mod config build gradle arguments delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle arguments edit

Configure Gradle build arguments.

Build arguments are added to the end of the Gradle command line when building LSTs.

Usage

mod config build gradle arguments edit

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle arguments show

Displays the configured Gradle additional build arguments.

Usage

mod config build gradle arguments show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle root (deprecated)

(DEPRECATED) Configure the directory containing the Gradle root build. This could be . to force the CLI to use the root directory of the repository as the Gradle build and look no deeper.

Use builds steps configuration instead. When this is set, the CLI does not attempt to find root Gradle builds in subdirectories or siblings recursively.

Usage

mod config build gradle root [subcommands]

Subcommands

  • delete: (DEPRECATED) Removes the configured directory containing the Gradle root build.
  • edit: (DEPRECATED) Configure the directory containing the Gradle root build.
  • show: (DEPRECATED) Displays the configured directory containing the Gradle root build.

mod config build gradle root delete (deprecated)

(DEPRECATED) Removes the configured directory containing the Gradle root build.

(DEPRECATED) Use builds steps configuration instead.

Usage

mod config build gradle root delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle root edit (deprecated)

(DEPRECATED) Configure the directory containing the Gradle root build.

Use builds steps configuration instead. When this is set, the CLI does not attempt to find root Gradle builds in subdirectories or siblings recursively.

Usage

mod config build gradle root edit [parameters]

Parameters

NameDescription
rootThe directory containing the Gradle root build.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle root show (deprecated)

(DEPRECATED) Displays the configured directory containing the Gradle root build.

Use build steps configuration instead.

Usage

mod config build gradle root show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle timeout

Configure the build timeout.

Limits the amount of time the CLI will wait for a single execution of the build tool.

Usage

mod config build gradle timeout [subcommands]

Subcommands

  • delete: Removes the configured build timeout.
  • edit: Configure the timeout for build operations.
  • show: Displays the configured build timeout.

mod config build gradle timeout delete

Removes the configured build timeout.

Usage

mod config build gradle timeout delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle timeout edit

Configure the timeout for build operations.

Limits the amount of time the CLI will wait for a single execution of the build tool. Setting this to too high of a value may cause mass ingestion to hang or appear to hang.

Usage

mod config build gradle timeout edit [parameters]

Parameters

NameDescription
durationThe duration of the timeout expressed as an ISO-8601 duration. For example: 'PT1H' for one hour, 'PT30M' for 30 minutes, 'PT1H30M' for one hour and 30 minutes.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build gradle timeout show

Displays the configured build timeout.

Usage

mod config build gradle timeout show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven

Configures Maven as it is used for LST production, resolving recipe dependencies, and when running recipes.

Usage

mod config build maven [subcommands]

Examples

mod config build maven settings edit <path-to-settings.xml>

Subcommands

  • arguments: Configure Maven build arguments.
  • settings: Configure Maven settings.
  • timeout: Configure the build timeout.

mod config build maven arguments

Configure Maven build arguments.

Build arguments are added to the end of the Maven command line when building LSTs.

Usage

mod config build maven arguments [subcommands]

Subcommands

  • delete: Removes additional build arguments for Maven.
  • edit: Configure Maven build arguments.
  • show: Displays the configured Maven additional build arguments.

mod config build maven arguments delete

Removes additional build arguments for Maven.

Usage

mod config build maven arguments delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven arguments edit

Configure Maven build arguments.

Build arguments are added to the end of the Maven command line when building LSTs.

Usage

mod config build maven arguments edit

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven arguments show

Displays the configured Maven additional build arguments.

Usage

mod config build maven arguments show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven settings

Configure Maven settings.

Allows you to specify the location of a Maven settings.xml file that should be used when Maven is being used to resolve recipe dependencies or run recipes. You can also use an environment variable that points to location of the file with ${ENV_VAR} syntax.

Usage

mod config build maven settings [subcommands]

Examples

mod config build maven settings edit <path-to-settings.xml>

Subcommands

  • delete: Removes the configured Maven settings.
  • edit: Configure Maven settings.
  • show: Displays the configured Maven settings.

mod config build maven settings delete

Removes the configured Maven settings.

Usage

mod config build maven settings delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven settings edit

Configure Maven settings.

Allows you to specify the location of a Maven settings.xml file that should be used when Maven is being used to resolve recipe dependencies or run recipes.

Usage

mod config build maven settings edit [parameters]

Examples

mod config build maven settings edit <path-to-settings.xml>

Parameters

NameDescription
settingsXmlThe location of a Maven settings.xml file to use.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven settings show

Displays the configured Maven settings.

Usage

mod config build maven settings show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven timeout

Configure the build timeout.

Limits the amount of time the CLI will wait for a single execution of the build tool.

Usage

mod config build maven timeout [subcommands]

Subcommands

  • delete: Removes the configured build timeout.
  • edit: Configure the timeout for build operations.
  • show: Displays the configured build timeout.

mod config build maven timeout delete

Removes the configured build timeout.

Usage

mod config build maven timeout delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven timeout edit

Configure the timeout for build operations.

Limits the amount of time the CLI will wait for a single execution of the build tool. Setting this to too high of a value may cause mass ingestion to hang or appear to hang.

Usage

mod config build maven timeout edit [parameters]

Parameters

NameDescription
durationThe duration of the timeout expressed as an ISO-8601 duration. For example: 'PT1H' for one hour, 'PT30M' for 30 minutes, 'PT1H30M' for one hour and 30 minutes.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config build maven timeout show

Displays the configured build timeout.

Usage

mod config build maven timeout show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config clone

Configures cloning behavior.

All subsequent clones will use these settings.

Usage

mod config clone [subcommands]

Subcommands

  • protocol: Configures the wire protocol(s) that are used for cloning.

mod config clone protocol

Configures the wire protocol(s) that are used for cloning.

All subsequent clones from Moderne organizations will use these settings. Clones from JSON or CSV use the explicitly provided clone URL without attempting to change the protocol.

Usage

mod config clone protocol [subcommands]

Subcommands

  • delete: Restores the default clone protocols.
  • edit: Configures the wire protocols that are used for cloning.
  • show: Displays the wire protocols that are used for cloning.

mod config clone protocol delete

Restores the default clone protocols.

The default is to attempt SSH and then HTTPS clones.

Usage

mod config clone protocol delete

mod config clone protocol edit

Configures the wire protocols that are used for cloning.

All subsequent clones will use these settings. The default is SSH and then HTTPS.

Usage

mod config clone protocol edit [parameters]

Parameters

NameDescription
protocolsThe protocol(s) to use for cloning. Must be one or both of 'ssh' or 'https' (case insensitive). The order in which they are provided establishes the order of precedence for subsequent clones.

mod config clone protocol show

Displays the wire protocols that are used for cloning.

This set governs all subsequent clone attempts.

Usage

mod config clone protocol show

mod config dotnet

Configures DotNet options used for building LSTs and running recipes.

Must be configured before you can run the commands that involve non-standard DotNet configurations.

Usage

mod config dotnet [subcommands]

Subcommands

  • installation: Configures locations of DotNet that can be used by build tools.

mod config dotnet installation

Configures locations of DotNet that can be used by build tools.

Must be configured before you can run the build command if DotNet is installed in non-standard locations.

Usage

mod config dotnet installation [subcommands]

Subcommands

  • edit: Configures locations of DotNet that can be used by build tools.
  • delete: Removes the configured DotNet installations. The CLI will revert to using only detectable DotNet installations.
  • list: Displays the detected and configured DotNet installations in the order in which they will be selected, constrained by versions detected from a particular repository.

mod config dotnet installation edit

Configures locations of DotNet that can be used by build tools.

Must be configured before you can run the build command if DotNet is installed in non-standard locations.

Usage

mod config dotnet installation edit [parameters]

Parameters

NameDescription
dotnetInstallationsThe paths on disk where DotNet installations can be found.

mod config dotnet installation delete

Removes the configured DotNet installations. The CLI will revert to using only detectable DotNet installations.

Usage

mod config dotnet installation delete

mod config dotnet installation list

Displays the detected and configured DotNet installations in the order in which they will be selected, constrained by versions detected from a particular repository.

Usage

mod config dotnet installation list

Options

NameDescription
--namedFilter the list of DotNet installations to .

mod config environment

The build environment that the CLI is running in.

Will output information about the environment the CLI is running in (e.g., a local developer machine vs. Gitlab CI).

Usage

mod config environment [subcommands]

Subcommands

  • show: The build environment that the CLI is running in.

mod config environment show

The build environment that the CLI is running in.

Will output information about the environment the CLI is running in (e.g., a local developer machine vs. Gitlab CI).

Usage

mod config environment show

mod config features

Configures experimental features.

Experimental features are not guaranteed to be stable and may change in future releases.

Usage

mod config features [subcommands]

Subcommands

  • index-recipes
  • no-maven-central: (INCUBATING) Configure the availability of Maven Central and OSS Sonatype Snapshots.
  • no-nuget-org: (INCUBATING) Configure the availability of NuGet.org.

mod config features index-recipes

Index recipes to avoid classloading expense on every repository. This experimental feature does not change the command line for running a recipe, but since recipes are instantiated differently, is considered experimental initially.

Usage

mod config features index-recipes

Options

NameDescription
--enabled

mod config features no-maven-central

(INCUBATING) Configure the availability of Maven Central and OSS Sonatype Snapshots.

Maven Central and OSS Sonatype Snapshots are considered as valid recipe and dependency sources by default. They are implicitly used as a fallback for the resolution of recipes. In some environments access to these repositories is not allowed. This command be used to disable adding them implicitly to the list of repositories used for installing running recipes.

Usage

mod config features no-maven-central

Options

NameDescription
--enabled

mod config features no-nuget-org

(INCUBATING) Configure the availability of NuGet.org.

NuGet.org is considered as a valid recipe and dependency source by default.It is implicitly used as a fallback for the resolution of recipes. In some environments access to these repositories is not allowed. This command be used to disable adding them implicitly to the list of repositories used for installing running recipes.

Usage

mod config features no-nuget-org

Options

NameDescription
--enabled

mod config http

Configures HTTP options that will be used throughout the CLI.

All subsequent commands will use these settings.

Usage

mod config http [subcommands]

Subcommands

  • proxy: Configures HTTP proxy settings that will be used for every HTTP request.
  • trust-store: Configures truststore options that will be used throughout the CLI.

mod config http proxy

Configures HTTP proxy settings that will be used for every HTTP request.

All subsequent commands will use these settings.

Usage

mod config http proxy [subcommands]

Subcommands

  • delete: Removes HTTP proxy settings from global configuration.
  • edit: Configures HTTP proxy settings that will be used for every HTTP request.
  • show: Displays the proxy settings from global configuration.

mod config http proxy delete

Removes HTTP proxy settings from global configuration.

Proxy settings will no longer be used for HTTP requests.

Usage

mod config http proxy delete

mod config http proxy edit

Configures HTTP proxy settings that will be used for every HTTP request.

All subsequent commands will use these settings.

Usage

mod config http proxy edit

Options

NameDescription
--host, --proxy-host
--port, --proxy-port

mod config http proxy show

Displays the proxy settings from global configuration.

Shows the currently configured proxy settings, if any.

Usage

mod config http proxy show

mod config http trust-store

Configures truststore options that will be used throughout the CLI.

All subsequent commands will use these settings.

Usage

mod config http trust-store [subcommands]

Subcommands

  • delete: Removes truststore settings from global configuration.
  • edit: Configures truststore options that will be used throughout the CLI.
  • show: Displays the truststore setting from global configuration.

mod config http trust-store delete

Removes truststore settings from global configuration.

Truststore settings will no longer be used for HTTP requests.

Usage

mod config http trust-store delete

mod config http trust-store edit

Configures truststore options that will be used throughout the CLI.

All subsequent commands will use these settings.

Usage

mod config http trust-store edit [subcommands]

Subcommands

  • system: Configures truststore to use the Operating System specific default truststore. On Mac the system trust store is accessed via the Keychain Access app. On Windows the system trust store is accessed via the Microsoft Management Console. On Linux there is no standardized trust store, so the cacerts file under ${JAVA_HOME}/lib/security/cacerts will be used.
  • file: Configures truststore to point to a file.
  • java-home: Configures truststore to use the cacerts file in ${JAVA_HOME}/lib/security/cacerts.

mod config http trust-store edit system

Configures truststore to use the Operating System specific default truststore. On Mac the system trust store is accessed via the Keychain Access app. On Windows the system trust store is accessed via the Microsoft Management Console. On Linux there is no standardized trust store, so the cacerts file under ${JAVA_HOME}/lib/security/cacerts will be used.

Usage

mod config http trust-store edit system

Options

NameDescription
--passwordThe password used to access the truststore.

mod config http trust-store edit file

Configures truststore to point to a file.

All subsequent commands will use this truststore.

Usage

mod config http trust-store edit file [parameters]

Parameters

NameDescription
fileThe path to the truststore file.

Options

NameDescription
--passwordThe password used to access the truststore.
--providerThe provider of the truststore.
--typeThe type of the truststore file.

mod config http trust-store edit java-home

Configures truststore to use the cacerts file in ${JAVA_HOME}/lib/security/cacerts.

Usage

mod config http trust-store edit java-home

mod config http trust-store show

Displays the truststore setting from global configuration.

Shows the currently configured truststore setting, if any.

Usage

mod config http trust-store show

mod config java

Configures Java options used for building LSTs and running recipes.

Must be configured before you can run the commands that involve non-standard Java configurations.

Usage

mod config java [subcommands]

Subcommands

  • jdk: Configures locations of JDKs that can be used by build tools.
  • options: Configures JVM options added to tools building LSTs.
  • version: Configures the JDK to use.

mod config java jdk

Configures locations of JDKs that can be used by build tools.

Must be configured before you can run the build command if JDKs are in non-standard locations.

Usage

mod config java jdk [subcommands]

Subcommands

  • edit: Configures locations of JDKs that can be used by build tools.
  • delete: Removes the configured JDK installations. The CLI will revert to using only detectable JDKs.
  • list: Displays the detected and configured JDK installations in the order in which they will be selected, constrained by versions detected from a particular repository.

mod config java jdk edit

Configures locations of JDKs that can be used by build tools.

Must be configured before you can run the build command if JDKs are in non-standard locations.

Usage

mod config java jdk edit [parameters]

Parameters

NameDescription
javaHomesThe paths on disk where JDK installations can be found.

mod config java jdk delete

Removes the configured JDK installations. The CLI will revert to using only detectable JDKs.

Usage

mod config java jdk delete

mod config java jdk list

Displays the detected and configured JDK installations in the order in which they will be selected, constrained by versions detected from a particular repository.

Usage

mod config java jdk list

Options

NameDescription
--namedFilter the list of JDKs to .

mod config java options

Configures JVM options added to tools building LSTs.

Must be configured before you can run the build command if non-standard VM options are required.

Usage

mod config java options [subcommands]

Subcommands

  • edit: Configures JVM options added to tools building LSTs.
  • delete: Removes configured JVM options. The CLI will no longer use custom JVM options.
  • show: Displays the configured JVM options.

mod config java options edit

Configures JVM options added to tools building LSTs.

Must be configured before you can run the build command if non-standard VM options are required.

Usage

mod config java options edit

Examples

mod config java options edit "\-Xmx4G"

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config java options delete

Removes configured JVM options. The CLI will no longer use custom JVM options.

Usage

mod config java options delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config java options show

Displays the configured JVM options.

Usage

mod config java options show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config java version

Configures the JDK to use.

Configure a name like "17", "17-tem", or "17.0.6-tem" depending on the degree of control needed.

Usage

mod config java version [subcommands]

Subcommands

  • edit: Configures the JDK to use.
  • delete: Reverts to auto-detection of a JDK to use when building a repository.
  • show: Displays the configured JDK version.

mod config java version edit

Configures the JDK to use.

Configure a name like "17", "17-tem", or "17.0.6-tem" depending on the degree of control needed.

Usage

mod config java version edit [parameters]

Examples

mod config java version edit "17-tem"

Parameters

NameDescription
selectedJdkThe named JDK to use. If set to "auto", the CLI will revert to detecting the correct JDK to use from signals available in the repository.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config java version delete

Reverts to auto-detection of a JDK to use when building a repository.

Usage

mod config java version delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config java version show

Displays the configured JDK version.

Usage

mod config java version show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config license

Configure a license key.

A license key allows for running recipes on private repositories without a connection to a Moderne tenant.

Usage

mod config license [subcommands]

Subcommands

  • delete: Removes the configured license key.
  • edit: Configure the active user.
  • show: Displays information about the configured license key.
  • moderne: Synchronizes a Moderne license key with the CLI.

mod config license delete

Removes the configured license key.

Usage

mod config license delete

mod config license edit

Configure the active user.

A license key allows for running recipes on private repositories without a connection to a Moderne tenant.

Usage

mod config license edit [parameters]

Parameters

NameDescription
licenseThe license key, provided by Moderne support.

mod config license show

Displays information about the configured license key.

Usage

mod config license show

Options

NameDescription
--json(INCUBATING) Output license information in JSON. The format of this JSON is unsettled at this point, and the data structuremay change.

mod config license moderne

Synchronizes a Moderne license key with the CLI.

A license key allows for running recipes on private repositories without a connection to a Moderne tenant.

Usage

mod config license moderne [subcommands]

Examples

mod config license moderne sync

Subcommands

  • sync: Synchronizes a Moderne license key with the CLI.

mod config license moderne sync

Synchronizes a Moderne license key with the CLI.

A license key allows for running recipes on private repositories without a connection to a Moderne tenant.

Usage

mod config license moderne sync

Examples

mod config license moderne sync

Options

NameDescription
--skip-sslIf this parameter is included, SSL verification will be skipped.

mod config lsts

Configures LSTs production and publishing.

Must be configured before you can run the publish command.

Usage

mod config lsts [subcommands]

Subcommands

  • artifacts: Configures the storage layer for LSTs to be published to and downloaded from.

mod config lsts artifacts

Configures the storage layer for LSTs to be published to and downloaded from.

Must be configured before you can run the publish command.

Usage

mod config lsts artifacts [subcommands]

Subcommands

  • artifactory: Configures the Artifactory repository that LSTs will be published to and downloaded from.
  • show: Displays the LST artifacts repository configuration.
  • maven: Configures a Maven-formatted artifact repository that LSTs will be published to and downloaded from.

mod config lsts artifacts artifactory

Configures the Artifactory repository that LSTs will be published to and downloaded from.

All subsequent publish and download commands will use this Artifactory repository.

Usage

mod config lsts artifacts artifactory [subcommands]

Subcommands

  • edit: Configures the repository that LSTs will be published to and downloaded from. Must be configured before you can run the publish command.
  • delete: Removes the Artifactory repository configuration. The publish command will no longer function until another artifact source is configured.
  • show: Displays the Artifactory repository configuration.

mod config lsts artifacts artifactory edit

Configures the repository that LSTs will be published to and downloaded from. Must be configured before you can run the publish command.

All subsequent publish and download commands will use this artifact repository.

Usage

mod config lsts artifacts artifactory edit [parameters]

Examples

mod config lsts artifacts edit <artifact-repository-url> --user <user> --password <password>

Parameters

NameDescription
urlThe URL of the artifact repository that LSTs will be published to.

Options

NameDescriptionExample
--authorizationThe authorization header value to use.Bearer XXXXX
--jfrog-api-tokenThe JFrog API token to use.
--passwordThe password to authenticate with.
--skip-sslIf this parameter is included, SSL verification will be skipped.
--userThe user to authenticate with.

mod config lsts artifacts artifactory delete

Removes the Artifactory repository configuration. The publish command will no longer function until another artifact source is configured.

Usage

mod config lsts artifacts artifactory delete

mod config lsts artifacts artifactory show

Displays the Artifactory repository configuration.

Usage

mod config lsts artifacts artifactory show

mod config lsts artifacts show

Displays the LST artifacts repository configuration.

Usage

mod config lsts artifacts show

mod config lsts artifacts maven

Configures a Maven-formatted artifact repository that LSTs will be published to and downloaded from.

All subsequent publish and download commands will use this Maven repository.

Usage

mod config lsts artifacts maven [subcommands]

Subcommands

  • edit: Configures the repository that LSTs will be published to and downloaded from. Must be configured before you can run the publish command.
  • delete: Removes the Maven artifact repository repository configuration. The publish command will no longer function until another artifact source is configured.
  • show: Displays the Maven artifact repository repository configuration.

mod config lsts artifacts maven edit

Configures the repository that LSTs will be published to and downloaded from. Must be configured before you can run the publish command.

All subsequent publish and download commands will use this artifact repository.

Usage

mod config lsts artifacts maven edit [parameters]

Examples

mod config lsts artifacts edit <artifact-repository-url> --user <user> --password <password>

Parameters

NameDescription
urlThe URL of the artifact repository that LSTs will be published to.

Options

NameDescriptionExample
--authorizationThe authorization header value to use.Bearer XXXXX
--localConfiguration relevant to a specific group of repositories.
--passwordThe password to authenticate with.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.
--skip-sslIf this parameter is included, SSL verification will be skipped.
--userThe user to authenticate with.

mod config lsts artifacts maven delete

Removes the Maven artifact repository repository configuration. The publish command will no longer function until another artifact source is configured.

Usage

mod config lsts artifacts maven delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config lsts artifacts maven show

Displays the Maven artifact repository repository configuration.

Usage

mod config lsts artifacts maven show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config moderne

Configures the connection to Moderne. Must be configured before you can install and run recipes.

All subsequent commands will use this Moderne tenant.

Usage

mod config moderne [subcommands]

Examples

mod config moderne edit <host> --token <token>

Subcommands

  • delete: Removes the configured Moderne tenant.
  • edit: Configures the connection to Moderne. Must be configured before you can install and run recipes.
  • local: Configures a connection to a Moderne DX instance running locally on the same machine.
  • show: Displays the Moderne tenant configuration.
  • organizations: The organizational hierarchy of repository ownership.

mod config moderne delete

Removes the configured Moderne tenant.

Usage

mod config moderne delete

mod config moderne edit

Configures the connection to Moderne. Must be configured before you can install and run recipes.

All subsequent commands will use this Moderne tenant.

Usage

mod config moderne edit [parameters]

Examples

mod config moderne edit <host> --token <token>

Parameters

NameDescription
hostThe URL of the Moderne UI.

Options

NameDescriptionExample
--apiThe URL of the tenant API gateway.https://api.app.moderne.io
--passwordThe password to authenticate with.
--skip-sslIf this parameter is included, SSL verification will be skipped.
--tokenThe Moderne personal access token to use.
--userThe user to authenticate with.

mod config moderne local

Configures a connection to a Moderne DX instance running locally on the same machine.

All subsequent commands will use this instance.

Usage

mod config moderne local

mod config moderne show

Displays the Moderne tenant configuration.

Usage

mod config moderne show

mod config moderne organizations

The organizational hierarchy of repository ownership.

Each of these organizations are cloneable.

Usage

mod config moderne organizations [subcommands]

Subcommands

  • show: Displays the Moderne view of organizational hierarchy.

mod config moderne organizations show

Displays the Moderne view of organizational hierarchy.

Usage

mod config moderne organizations show

Options

NameDescription
--json

mod config recipes

Configures the recipe marketplace available to the CLI. Must be configured before you can run recipes.

You must run the mod config moderne command before running this command so that the CLI knows where to download recipes from.

Usage

mod config recipes [subcommands]

Examples

mod config recipes moderne sync

Subcommands

  • artifacts: Configures artifact repositories to resolve recipes from.
  • export: Export the recipe catalog for study by different tools.
  • jar: Adds or updates an artifact that contains recipes that should be added to the recipe marketplace in the CLI.
  • nupkg: Adds or updates a package that contains recipes that should be added to the recipe marketplace in the CLI.
  • moderne: Configures which Moderne recipes should be installed and used in the local CLI marketplace.
  • delete: Clear the whole recipe marketplace.
  • list: List the artifacts that are contributing recipes to the marketplace.
  • search: Finds recipes based on free form text search.
  • yaml: Adds or updates a YAML file that contains recipes that should be added to the recipe marketplace in the CLI.

mod config recipes artifacts

Configures artifact repositories to resolve recipes from.

Defaults to resolving recipes from Maven Central and Nexus Snapshots.

Usage

mod config recipes artifacts [subcommands]

Subcommands

  • artifactory: Configures the artifact repository to resolve recipes from.
  • show: Displays the recipe artifacts repository configuration.
  • default-repositories: Configure the availability of maven central repositories.
  • maven: Configures a Maven-formatted artifact repository that recipes will be resolved from.
  • nuget: Configures a Nuget-formatted artifact repository that recipes will be resolved from.

mod config recipes artifacts artifactory

Configures the artifact repository to resolve recipes from.

All subsequent recipe installation commands will use this Artifactory repository.

Usage

mod config recipes artifacts artifactory [subcommands]

Subcommands

  • edit: Configures the artifact repository to resolve recipes from.
  • delete: Removes the Artifactory repository configuration.
  • show: Displays the Artifactory repository configuration.

mod config recipes artifacts artifactory edit

Configures the artifact repository to resolve recipes from.

All subsequent recipe installation commands will use this artifact repository.

Usage

mod config recipes artifacts artifactory edit [parameters]

Examples

mod config recipes artifacts edit <artifact-repository-url> --user <user> --password <password>

Parameters

NameDescription
urlThe URL of the artifact repository that recipes will be resolved from.

Options

NameDescriptionExample
--authorizationThe authorization header value to use.Bearer XXXXX
--jfrog-api-tokenThe JFrog API token to use.
--passwordThe password to authenticate with.
--skip-sslIf this parameter is included, SSL verification will be skipped.
--userThe user to authenticate with.

mod config recipes artifacts artifactory delete

Removes the Artifactory repository configuration.

Usage

mod config recipes artifacts artifactory delete

mod config recipes artifacts artifactory show

Displays the Artifactory repository configuration.

Usage

mod config recipes artifacts artifactory show

mod config recipes artifacts show

Displays the recipe artifacts repository configuration.

Usage

mod config recipes artifacts show

mod config recipes artifacts default-repositories (deprecated)

Configure the availability of maven central repositories.

Use mod config features no-maven-central to disable/enable Maven Central and OSS Sonatype Snapshots.

Usage

mod config recipes artifacts default-repositories [subcommands]

Subcommands

  • enable
  • disable
  • show

mod config recipes artifacts default-repositories enable (deprecated)

(INCUBATING) Enable default repositories.

Usage

mod config recipes artifacts default-repositories enable

mod config recipes artifacts default-repositories disable (deprecated)

(INCUBATING) Disable default repositories.

Usage

mod config recipes artifacts default-repositories disable

mod config recipes artifacts default-repositories show (deprecated)

(INCUBATING) Show the current configuration of default repositories.

Usage

mod config recipes artifacts default-repositories show

mod config recipes artifacts maven

Configures a Maven-formatted artifact repository that recipes will be resolved from.

All subsequent recipe installation commands will use this Maven repository.

Usage

mod config recipes artifacts maven [subcommands]

Subcommands

  • edit: Configures the repository that recipes will be resolved from.
  • delete: Removes the Maven artifact repository repository configuration.
  • show: Displays the Maven artifact repository repository configuration.

mod config recipes artifacts maven edit

Configures the repository that recipes will be resolved from.

All subsequent recipe installation commands will use this artifact repository.

Usage

mod config recipes artifacts maven edit [parameters]

Examples

mod config recipes artifacts edit <artifact-repository-url> --user <user> --password <password>

Parameters

NameDescription
urlThe URL of the artifact repository that recipes will be resolved from.

Options

NameDescriptionExample
--authorizationThe authorization header value to use.Bearer XXXXX
--passwordThe password to authenticate with.
--skip-sslIf this parameter is included, SSL verification will be skipped.
--userThe user to authenticate with.

mod config recipes artifacts maven delete

Removes the Maven artifact repository repository configuration.

Usage

mod config recipes artifacts maven delete

mod config recipes artifacts maven show

Displays the Maven artifact repository repository configuration.

Usage

mod config recipes artifacts maven show

mod config recipes artifacts nuget

Configures a Nuget-formatted artifact repository that recipes will be resolved from.

All subsequent recipe installation commands will use this Nuget repository.

Usage

mod config recipes artifacts nuget [subcommands]

Subcommands

  • edit: Configures the repository that recipes will be resolved from.
  • delete: Removes the Nuget artifact repository repository configuration.
  • show: Displays the Nuget artifact repository repository configuration.

mod config recipes artifacts nuget edit

Configures the repository that recipes will be resolved from.

All subsequent recipe installation commands will use this artifact repository.

Usage

mod config recipes artifacts nuget edit [parameters]

Examples

mod config recipes nuget edit <artifact-repository-url> --user <user> --password <password>

Parameters

NameDescription
urlThe URL of the artifact repository that recipes will be resolved from.

Options

NameDescriptionExample
--authorizationThe authorization header value to use.Bearer XXXXX
--passwordThe password to authenticate with.
--skip-sslIf this parameter is included, SSL verification will be skipped.
--userThe user to authenticate with.

mod config recipes artifacts nuget delete

Removes the Nuget artifact repository repository configuration.

Usage

mod config recipes artifacts nuget delete

mod config recipes artifacts nuget show

Displays the Nuget artifact repository repository configuration.

Usage

mod config recipes artifacts nuget show

mod config recipes export

Export the recipe catalog for study by different tools.

Usage

mod config recipes export [subcommands]

Subcommands

  • json: Export recipe details as JSON.
  • csv: Export recipe details as CSV.

mod config recipes export json

Export recipe details as JSON.

Usage

mod config recipes export json [parameters]

Parameters

NameDescription
outputThe path to the output JSON file.

mod config recipes export csv

Export recipe details as CSV.

Usage

mod config recipes export csv [parameters]

Parameters

NameDescription
outputThe path to the output CSV file.

mod config recipes jar

Adds or updates an artifact that contains recipes that should be added to the recipe marketplace in the CLI.

The recipes defined by this artifact will then be available to run.

Usage

mod config recipes jar [subcommands]

Examples

mod config recipes jar install org.openrewrite:rewrite-java:LATEST

Subcommands

  • install: Adds or updates an artifact that contains recipes that should be added to the recipe marketplace in the CLI.
  • delete: Removes an artifact supplying recipes to the marketplace.

mod config recipes jar install

Adds or updates an artifact that contains recipes that should be added to the recipe marketplace in the CLI.

The recipes defined by this artifact will then be available to run.

Usage

mod config recipes jar install [parameters]

Examples

mod config recipes jar install org.openrewrite:rewrite-java:LATEST

Parameters

NameDescription
GAVThe group, artifact, and version of the artifact to install in the format groupId:artifactId:version. The version may be a fixed version, LATEST, or RELEASE.
The dependency will be resolved from the artifact source defined in mod config recipes artifacts

Options

NameDescription
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.
--repository-url, --repositoryThe repository URL that the artifact will be resolved from.

mod config recipes jar delete

Removes an artifact supplying recipes to the marketplace.

The recipes defined by this artifact will then no longer be available to run.

Usage

mod config recipes jar delete [parameters]

Examples

mod config recipes jar delete rewrite-java

Parameters

NameDescription
artifactAn artifact name or group and artifact name.

mod config recipes nupkg

Adds or updates a package that contains recipes that should be added to the recipe marketplace in the CLI.

The recipes defined by this package will then be available to run.

Usage

mod config recipes nupkg [subcommands]

Examples

mod config recipes nupkg install rewrite.java:LATEST

Subcommands

  • install: Adds or updates a package that contains recipes that should be added to the recipe marketplace in the CLI.
  • delete: Removes a package supplying recipes to the marketplace.

mod config recipes nupkg install

Adds or updates a package that contains recipes that should be added to the recipe marketplace in the CLI.

The recipes defined by this package will then be available to run.

Usage

mod config recipes nupkg install [parameters]

Examples

mod config recipes nupkg install rewrite.java:LATEST

Parameters

NameDescription
PIVThe package id, and version of the package to install in the format packageId:version. The version may be a fixed version, LATEST, or RELEASE.
The dependency will be resolved from the package source defined in mod config lsts artifacts

Options

NameDescription
--repository-url, --repositoryThe repository URL that the package will be resolved from.

mod config recipes nupkg delete

Removes a package supplying recipes to the marketplace.

The recipes defined by this package will then no longer be available to run.

Usage

mod config recipes nupkg delete [parameters]

Examples

mod config recipes nupkg delete rewrite.java

Parameters

NameDescription
artifactAn package id.

mod config recipes moderne

Configures which Moderne recipes should be installed and used in the local CLI marketplace.

The recipes installed will then be available to run locally.

Usage

mod config recipes moderne [subcommands]

Examples

mod config recipes moderne install <SEARCH_TERM>
mod config recipes moderne sync

Subcommands

  • install: Allows you to find and install recipes from Moderne.
  • push: Pushes the local CLI recipe marketplace to Moderne.
  • sync: Synchronizes the local CLI recipe marketplace with Moderne.

mod config recipes moderne install

Allows you to find and install recipes from Moderne.

After providing a search term, the Moderne API will be queried to find recipes that match it. You will be provided with up to 10 possible matches and the option to select one to install. If you select to install one, the appropriate JAR will be downloaded and added to your local CLI marketplace. The recipes defined by this artifact will then be available to run.

Usage

mod config recipes moderne install [parameters]

Examples

mod config recipes moderne install <SEARCH_TERM>
mod config recipes moderne install FindTypes
mod config recipes moderne install "Migrate Java"

Parameters

NameDescription
searchTermThe search term to use to find recipes to install.

mod config recipes moderne push

Pushes the local CLI recipe marketplace to Moderne.

Adds or replaces all recipes in the Moderne tenant with the recipes installed in the local marketplace.

Usage

mod config recipes moderne push

Options

NameDescription
-f, --forceForce the push of the local CLI recipe marketplace to Moderne, replacing all installed recipe artifacts with the contents of the local marketplace.

mod config recipes moderne sync

Synchronizes the local CLI recipe marketplace with Moderne.

Destroys all recipes in the local CLI marketplace and replaces them with the latest recipes available in Moderne. The recipes defined by these artifacts will then be available to run.

Usage

mod config recipes moderne sync

Options

NameDescription
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.

mod config recipes delete

Clear the whole recipe marketplace.

No recipes will be available to run until they are installed again.

Usage

mod config recipes delete

mod config recipes list

List the artifacts that are contributing recipes to the marketplace.

Usage

mod config recipes list

Finds recipes based on free form text search.

The found recipes may then be set as the active recipe. Multiple word searches may, but don't need to surrounded by quotes on the command line.

Usage

mod config recipes search [parameters]

Examples

mod config recipes search owasp

Parameters

NameDescription
query

Options

NameDescription
--limitThe maximum total number of results that will be returned.

mod config recipes yaml

Adds or updates a YAML file that contains recipes that should be added to the recipe marketplace in the CLI.

The recipes defined in this YAML file will then be available to run.

Usage

mod config recipes yaml [subcommands]

Examples

mod config recipes yaml install /path/to/yaml

Subcommands

  • install: Adds or updates a YAML file that contains recipes that should be added to the recipe marketplace in the CLI.
  • delete: Removes an artifact supplying recipes to the marketplace.

mod config recipes yaml install

Adds or updates a YAML file that contains recipes that should be added to the recipe marketplace in the CLI.

The recipes defined in this YAML file will then be available to run.

Usage

mod config recipes yaml install [parameters]

Examples

mod config recipes yaml install /path/to/yaml

Parameters

NameDescription
pathsThe path to the YAML file to install. The YAML file will be copied, so if further modifications to it are made, make sure to reinstall it.

mod config recipes yaml delete

Removes an artifact supplying recipes to the marketplace.

The recipes defined by this artifact will then no longer be available to run.

Usage

mod config recipes yaml delete [parameters]

Examples

mod config recipes yaml delete /path/to/yml

Parameters

NameDescription
pathThe path to the YAML file to uninstall.

mod config run

Configures recipe run behavior.

All subsequent runs will use these settings

Usage

mod config run [subcommands]

Subcommands

  • timeout: Configure the run timeout.

mod config run timeout

Configure the run timeout.

Limits the amount of time the CLI will wait for a single execution of a recipe run.

Usage

mod config run timeout [subcommands]

Subcommands

  • delete: Restores the configured run timeout to the default value.
  • edit: Configure the timeout for recipe runs.
  • show: Displays the configured run timeout.

mod config run timeout delete

Restores the configured run timeout to the default value.

Usage

mod config run timeout delete

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config run timeout edit

Configure the timeout for recipe runs.

Limits the amount of time the CLI will wait for a single execution of a recipe run.

Usage

mod config run timeout edit [parameters]

Parameters

NameDescription
durationThe duration of the timeout expressed as an ISO-8601 duration. For example: 'PT1H' for one hour, 'PT30M' for 30 minutes, 'PT1H30M' for one hour and 30 minutes.

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config run timeout show

Displays the configured run timeout.

Usage

mod config run timeout show

Options

NameDescriptionExample
--localConfiguration relevant to a specific group of repositories.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--saveWhen applied to a group of repositories, indicates that the configuration should be placed in a .modernecfg which can be committed to source control. When applied to global configuration, this option has no effect.

mod config scm

Configures source code management.

Usage

mod config scm [subcommands]

Subcommands

  • gitlab: (DEPRECATED) Configures GitLab.
  • bitbucket: (DEPRECATED) Configures Bitbucket.
  • moderne: (INCUBATING) Configures the SCM configuration with Moderne
  • add
  • remove
  • show: Displays the configured SCMs

mod config scm gitlab

(DEPRECATED) Configures GitLab.

Use mod config scm show|add|remove in stead

Usage

mod config scm gitlab [subcommands]

Subcommands

  • base-url: (DEPRECATED) Configure the base URL.
  • base-urls: (DEPRECATED) Configure the base URLs.

mod config scm gitlab base-url (deprecated)

(DEPRECATED) Configure the base URL.

(DEPRECATED) use mod config scm show|add|remove in stead

Usage

mod config scm gitlab base-url [subcommands]

Examples

mod config scm gitlab base-url edit "https://acme.com/gitlab-ee/"

Subcommands

  • delete: (DEPRECATED) Removes base URL customization.
  • edit: (DEPRECATED) Configure the base URL.
  • show: (DEPRECATED) Displays the configured base URLs.

mod config scm gitlab base-url delete (deprecated)

(DEPRECATED) Removes base URL customization.

Usage

mod config scm gitlab base-url delete

mod config scm gitlab base-url edit (deprecated)

(DEPRECATED) Configure the base URL.

(DEPRECATED) use mod config scm show|add|remove in stead

Usage

mod config scm gitlab base-url edit [parameters]

Parameters

NameDescription
baseUrlThe base URL to use when determining paths.

mod config scm gitlab base-url show (deprecated)

(DEPRECATED) Displays the configured base URLs.

Usage

mod config scm gitlab base-url show

mod config scm gitlab base-urls

(DEPRECATED) Configure the base URLs.

(DEPRECATED) use mod config scm show|add|remove in stead

Usage

mod config scm gitlab base-urls [subcommands]

Examples

mod config scm gitlab base-urls edit "https://acme.com/gitlab-ee/"

Subcommands

  • delete: (DEPRECATED) Removes base URL customization.
  • edit: (DEPRECATED) Configure one or more base URLs.
  • show: (DEPRECATED) Displays the configured base URLs.

mod config scm gitlab base-urls delete

(DEPRECATED) Removes base URL customization.

Usage

mod config scm gitlab base-urls delete

mod config scm gitlab base-urls edit

(DEPRECATED) Configure one or more base URLs.

Usage

mod config scm gitlab base-urls edit [parameters]

Parameters

NameDescription
baseUrlsThe base URLs to use when determining paths.

mod config scm gitlab base-urls show

(DEPRECATED) Displays the configured base URLs.

Usage

mod config scm gitlab base-urls show

mod config scm bitbucket

(DEPRECATED) Configures Bitbucket.

(DEPRECATED) use mod config scm show|add|remove in stead

Usage

mod config scm bitbucket [subcommands]

Subcommands

  • base-urls: (DEPRECATED) Configure the base URLs.

mod config scm bitbucket base-urls

(DEPRECATED) Configure the base URLs.

(DEPRECATED) use mod config scm show|add|remove in stead

Usage

mod config scm bitbucket base-urls [subcommands]

Examples

mod config scm bitbucket base-urls edit "https://bitbucket.acme.com/stash/"

Subcommands

  • delete: (DEPRECATED) Removes base URL customization.
  • edit: (DEPRECATED) Configure one or more base URLs.
  • show: (DEPRECATED) Displays the configured base URLs.

mod config scm bitbucket base-urls delete

(DEPRECATED) Removes base URL customization.

Usage

mod config scm bitbucket base-urls delete

mod config scm bitbucket base-urls edit

(DEPRECATED) Configure one or more base URLs.

Usage

mod config scm bitbucket base-urls edit [parameters]

Parameters

NameDescription
baseUrlsThe base URLs to use when determining paths.

mod config scm bitbucket base-urls show

(DEPRECATED) Displays the configured base URLs.

Usage

mod config scm bitbucket base-urls show

mod config scm moderne

(INCUBATING) Configures the SCM configuration with Moderne

Usage

mod config scm moderne [subcommands]

Examples

mod config scm moderne sync

Subcommands

  • sync: Synchronizes the SCM configuration with your Moderne instance

mod config scm moderne sync

Synchronizes the SCM configuration with your Moderne instance

Usage

mod config scm moderne sync

mod config scm add

(INCUBATING) Add an SCM configuration

Usage

mod config scm add [parameters]

Parameters

NameDescription
typeThe SCM type
baseUrlThe primary SCM URL

Options

NameDescription
--alternate-urlAlternate SCM URLs

mod config scm remove

(INCUBATING) Remove an SCM configuration by type and URL

Usage

mod config scm remove [parameters]

Parameters

NameDescription
type
baseUrl

mod config scm show

Displays the configured SCMs

Usage

mod config scm show

mod config user

Configure the active user.

The active user is reported for activity metrics in Moderne DX environments. If not explicitly set in mod config, the active user is inferred from global git configuration.

Usage

mod config user [subcommands]

Subcommands

  • delete: Removes the configured active user.
  • edit: Configure the active user.
  • show: Displays the configured active user.

mod config user delete

Removes the configured active user.

Usage

mod config user delete

mod config user edit

Configure the active user.

The active user is reported for activity metrics in Moderne DX environments.

Usage

mod config user edit

Options

NameDescription
--emailThe email of the active user.
--nameThe name of the active user.

mod config user show

Displays the configured active user.

Usage

mod config user show

mod devcenter

DevCenter operations.

Usage

mod devcenter [subcommands]

Subcommands

  • run: (INCUBATING) Runs all configured DevCenter recipes.

mod devcenter run

(INCUBATING) Runs all configured DevCenter recipes.

Usage

mod devcenter run [parameters]

Examples

mod devcenter run /path/to/organization

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--output-dir
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod exec

Execute an arbitrary shell command recursively on selected repository roots.

If you want to execute a command that contains positional parameters, please ensure that you use the end-of-options POSIX delimiter (--) before your command, such as in the following example:

mod exec /path/to/project -- gh pr create --title "Test PR" --body "Test PR".

Commands can take advantage of a set of variables computed by mod exec specific to the repository the command is executed on. For example, mod exec . MODERNE_BUILD_TOOL_CHECK will substitute MODERNE_BUILD_TOOL_CHECK with the build tool command to execute verification tasks specific to the repository. This would expand to gradle check and mvn verify for Gradle and Maven projects, respectively. Additionally, each computed variable is added to the environment the command is run in.

The list of computed variables include MODERNE_JAVA_HOME, MODERNE_JAVA_VERSION, MODERNE_JAVA_JDK, MODERNE_BUILD_TOOL, MODERNE_BUILD_TOOL_COMPILE, MODERNE_BUILD_TOOL_CHECK, and MODERNE_BUILD_TOOL_DIR

Usage

mod exec [parameters]

Examples

mod exec /path/to/project rm *.hprof

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
cmdThe shell command that you wish to run on the selected repository roots.
argsArguments for the command, if any exist.

Options

NameDescriptionExample
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
-o, --out, --outputThe output type for the command. If not specified, the output will be printed to the console.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git

Multi-repository git operations.

Usage

mod git [subcommands]

Subcommands

  • add: Performs the equivalent of git add on multiple repositories.
  • apply: Performs the equivalent of git apply on multiple repositories.
  • checkout: Performs the equivalent of git checkout on multiple repositories.
  • clone: Performs the equivalent of git clone on multiple repositories.
  • commit: Performs the equivalent of git commit on multiple repositories.
  • pull: Performs the equivalent of git pull on multiple repositories.
  • push: Performs the equivalent of git push on multiple repositories.
  • reset: Performs the equivalent of git reset on multiple repositories.
  • rev-parse: Performs the equivalent of git rev-parse on multiple repositories.
  • stashset: Performs the equivalent of git stash on multiple repositories.
  • stashset: Performs the equivalent of git stash on multiple repositories.
  • sync: Synchronizing with Moderne.
  • status: Performs the equivalent of git status on multiple repositories.

mod git add

Performs the equivalent of git add on multiple repositories.

Rather than applying git add one at a time, this operates on multiple repositories.

Usage

mod git add [parameters]

Examples

mod git add /path/to/project --recipe-run <recipe-run-id>

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git apply

Performs the equivalent of git apply on multiple repositories.

Rather than applying one patch at a time, this operates on multiple repositories.

Usage

mod git apply [parameters]

Examples

mod git apply /path/to/project --recipe-run 20230903164310-2qVRM

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git checkout

Performs the equivalent of git checkout on multiple repositories.

Rather than checking out one repository at a time, this operates on multiple repositories.

Usage

mod git checkout [parameters]

Examples

mod git checkout /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
branchThe branch to checkout.

Options

NameDescriptionExample
-b, -BCauses a new branch to be created as if git-branch were called and then checked out.
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git clone

Performs the equivalent of git clone on multiple repositories.

Rather than cloning one at a time, this operates on multiple repositories. The list of repositories can be sourced from different places, like Moderne or a CSV.

Usage

mod git clone [subcommands]

Examples

mod git clone moderne /path/to/folder/to/clone/into Apache

Subcommands

  • csv: Clones the repositories listed in a CSV file.
  • json: Clones the repositories listed in a JSON file.
  • moderne: Clones the repositories in an organization on Moderne.

mod git clone csv

Clones the repositories listed in a CSV file.

The CSV file should have a header row with the required column cloneUrl and any number of optional columns. The optional columns are branch, changeset, java, jvmOpts, mavenArgs, gradleArgs, bazelRule.

Usage

mod git clone csv [parameters]

Parameters

NameDescription
cloneIntoThe directory to clone all projects into. This directory will be created if it doesn't exist.
csvThe path to a CSV file containing repositories to clone.

Options

NameDescription
--depthEquivalent to the git clone --depth option.
--filterEquivalent to the git clone --filter option.
--limitThe maximum number of repositories to clone.
--metadata-only, --metadataDo not perform a traditional git clone, but rather just record the repository origin, path, branch, and changeset in a 'repository' folder.
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.
--saveAny per repository configuration should be placed in a .modernecfg which can be committed to source control.
--single-branch

mod git clone json

Clones the repositories listed in a JSON file.

The JSON file should consist of an array of repositories with the required keys cloneUrl| and @|bold branch and any number of optional keys. The optional keys are changeset, java, jvmOpts, mavenArgs, gradleArgs, bazelRule.

Usage

mod git clone json [parameters]

Parameters

NameDescription
cloneIntoThe directory to clone all projects into. This directory will be created if it doesn't exist.
jsonThe path to a JSON file containing repositories to clone.

Options

NameDescription
--depthEquivalent to the git clone --depth option.
--filterEquivalent to the git clone --filter option.
--limitThe maximum number of repositories to clone.
--metadata-only, --metadataDo not perform a traditional git clone, but rather just record the repository origin, path, branch, and changeset in a 'repository' folder.
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.
--saveAny per repository configuration should be placed in a .modernecfg which can be committed to source control.
--single-branch

mod git clone moderne

Clones the repositories in an organization on Moderne.

The repositories are cloned at the same branch and changeset of the LST that represents that repository in the organization in Moderne so that a subsequent mod build will trivially match and download the LST from Moderne.

Usage

mod git clone moderne [parameters]

Parameters

NameDescription
cloneIntoThe directory to clone all projects into. This directory will be created if it doesn't exist.
organizationThe name of an organization in Moderne. All repositories in that organization will be cloned at the branch and commit of their current LSTs.

Options

NameDescription
--depthEquivalent to the git clone --depth option.
--filterEquivalent to the git clone --filter option.
--limitThe maximum number of repositories to clone.
--metadata-only, --metadataDo not perform a traditional git clone, but rather just record the repository origin, path, branch, and changeset in a 'repository' folder.
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.
--single-branch

mod git commit

Performs the equivalent of git commit on multiple repositories.

Rather than applying one commit at a time, this operates on multiple repositories.

Usage

mod git commit [parameters]

Examples

mod git commit /path/to/project -m "commit message"

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
-m, --messageThe commit message to use.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git pull

Performs the equivalent of git pull on multiple repositories.

Rather than pulling one repository at a time, this operates on multiple repositories.

Usage

mod git pull [parameters]

Examples

mod git pull /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--rebasePull with rebase or not.github.com
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git push

Performs the equivalent of git push on multiple repositories.

Rather than pushing one repository at a time, this operates on multiple repositories.

Usage

mod git push [parameters]

Examples

mod git push /path/to/project -u origin feature-branch

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
repository
refspecSpecify what destination ref to update with what source object.

Options

NameDescriptionExample
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--u, --set-upstreamFor every branch that is up to date or successfully pushed, add upstream (tracking) reference.

mod git reset

Performs the equivalent of git reset on multiple repositories.

Rather than applying one stash at a time, this operates on multiple repositories.

Usage

mod git reset [parameters]

Examples

mod git reset /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--hardResets the index and working tree.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git rev-parse

Performs the equivalent of git rev-parse on multiple repositories.

Rather than applying one rev-parse at a time, this operates on multiple repositories.

Usage

mod git rev-parse [parameters]

Examples

mod git rev-parse /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
args

Options

NameDescriptionExample
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git stashset

Performs the equivalent of git stash on multiple repositories.

Rather than applying one stash at a time, this operates on multiple repositories.

This command does not affect the stash log of the repository, but rather stores the otherwise untracked commit in a multi-repository stash file in Moderne configuration, so the whole 'stashset' can be applied at once atomically.

Usage

mod git stashset [subcommands]

Examples

mod git stashset /path/to/project

Subcommands

  • apply: Performs the equivalent of git stash apply on multiple repositories.
  • push: Performs the equivalent of git stash push on multiple repositories.

mod git stashset apply

Performs the equivalent of git stash apply on multiple repositories.

Usage

mod git stashset apply [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
refThe stash ref to apply.

Options

NameDescriptionExample
--forcePop the stash after applying it, regardless of whether it made a change.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git stashset push

Performs the equivalent of git stash push on multiple repositories.

Usage

mod git stashset push [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
-u, --include-untrackedInclude untracked files.

mod git stashset

Performs the equivalent of git stash on multiple repositories.

Rather than applying one stash at a time, this operates on multiple repositories.

This command does not affect the stash log of the repository, but rather stores the otherwise untracked commit in a multi-repository stash file in Moderne configuration, so the whole 'stashset' can be applied at once atomically.

Usage

mod git stashset [subcommands]

Examples

mod git stashset /path/to/project

Subcommands

  • apply: Performs the equivalent of git stash apply on multiple repositories.
  • push: Performs the equivalent of git stash push on multiple repositories.

mod git stashset apply

Performs the equivalent of git stash apply on multiple repositories.

Usage

mod git stashset apply [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
refThe stash ref to apply.

Options

NameDescriptionExample
--forcePop the stash after applying it, regardless of whether it made a change.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git stashset push

Performs the equivalent of git stash push on multiple repositories.

Usage

mod git stashset push [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
-u, --include-untrackedInclude untracked files.

mod git sync

Synchronizing with Moderne.

Usage

mod git sync [subcommands]

Subcommands

  • moderne: Synchronizes the repositories and metadata of an organization on Moderne.

mod git sync moderne

Synchronizes the repositories and metadata of an organization on Moderne.

The repositories are cloned or pulled at the same branch and changeset of the LST that represents that repository in the organization in Moderne so that a subsequent mod build will trivially match and download the LST from Moderne. If the repository has local changes or is on a different branch no changes will be made.

Usage

mod git sync moderne [parameters]

Examples

mod git sync moderne /path/to/organization

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
--metadata-only, --metadataDo not perform a traditional git clone, but rather just record the repository origin, path, branch, and changeset in a 'repository' folder.
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod git status

Performs the equivalent of git status on multiple repositories.

Rather than applying git status one at a time, this operates on multiple repositories.

Usage

mod git status [parameters]

Examples

mod git status /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod log

Manages a log aggregate.

Used to understand holistically how a build performed on many repositories. In contrast to a CI build log which is designed to look at one repository at a time, a log aggregate is designed to look at many repositories at once, illuminating the common causes of failure (or success) and the overall health of the ingestion process.

Usage

mod log [subcommands]

Subcommands

  • builds: Adds a set of build logs to a log aggregate.
  • runs: Adds a set of run logs to a log aggregate.

mod log builds

Adds a set of build logs to a log aggregate.

In contrast to a CI build log which is designed to look at one repository at a time, a log aggregate is designed to look at many repositories at once, illuminating the common causes of failure (or success) and the overall health of the ingestion process.

Usage

mod log builds [subcommands]

Subcommands

  • add: Adds a set of build logs to a log aggregate.

mod log builds add

Adds a set of build logs to a log aggregate.

For each repository that has a matching build, add its build log to the aggregate.

Usage

mod log builds add [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
logPathThe absolute or relative path on disk to a log aggregate (a zip file). The file need not exist, though its containing directory is expected to exist.

Options

NameDescriptionExample
--buildA build ID for a build that has completed previously.
--last-buildSelect whatever the last build was, whether the build ran fully to completion or terminated early.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod log runs

Adds a set of run logs to a log aggregate.

In contrast to a CI log which is designed to look at one repository at a time, a log aggregate is designed to look at many repositories at once, illuminating the common causes of failure (or success) and the overall health of a recipe run.

Usage

mod log runs [subcommands]

Subcommands

  • add: Adds a set of run logs to a log aggregate.

mod log runs add

Adds a set of run logs to a log aggregate.

For each repository that has a matching run, add its run log to the aggregate.

Usage

mod log runs add [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.
logPathThe absolute or relative path on disk to a log aggregate (a zip file). The file need not exist, though its containing directory is expected to exist.

Options

NameDescriptionExample
--last-runSelect whatever the last run was, whether the run ran fully to completion or terminated early.
--organizationOrganization name to override the organization associated with each run.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--runA run ID for a run that has completed previously.

mod list

Lists the repositories that can be built and published.

Usage

mod list [parameters]

Examples

mod list /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--json(INCUBATING) Output the repository listing in JSON. The format of this JSON is unsettled at this point, and the data structuremay change.
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod monitor

(INCUBATING) Launches an HTTP server used to monitor the CLI.

This command will launch an HTTP server and block, so should be used in combination with backgrounding the process and redirecting its output as needed. The server will respond to GET requests on http://localhost:<PORT>/prometheus in the Prometheus exposition format.

Usage

mod monitor

Options

NameDescription
--portThe port to listen on. Default is 8080.

mod publish

Publishes the LST artifacts for one or more projects.

Once published to your artifact repository, Moderne will be able to ingest them and they will, in turn, be usable inside of Moderne.

You must run mod build before you can run this command. You also must set up an artifact repository connection by running mod config lsts artifacts before this command will work.

Usage

mod publish [parameters]

Examples

mod publish /path/to/project

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--partition(INCUBATING) The name of the partitions to publish. If not specified, the recipe will publish all partitions (or the whole repository if there are no partitions).
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod run

Runs an OpenRewrite recipe locally on pre-built LSTS.

You must run the mod build command before this command will work. You also must set up a connection to moderne (mod config moderne) and install recipes (mod config recipes) for this command to work.

Usage

mod run [parameters]

Examples

mod run /path/to/project \
--recipe=org.openrewrite.java.search.FindMethods \
-P methodPattern='java.util.List add(..)'

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--active-recipeIf this flag is included, the recipe specified as the active recipe in your IDE will be run (assuming you have the Moderne plugin installed and configured).
--jvm-debugStart a JDWP server on this port and pause for a remote debug connection.
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
--no-patch(INCUBATING) Do not generate patch files on disk at the conclusion of a recipe run that makes changes. This is useful when you are looking to only use data table outputs and don't wish to incur the cost of writing patch files when they will be unused.
-P, --recipe-optionRecipe options, if any. If a recipe accepts more than one option, you can include this argument multiple times.mod run . --recipe=<recipe> -P methodPattern='java.util.List add(..)' -P moreOptions='moreOptions'
--parallel(INCUBATING) Run the command in parallel. Setting this option to 2 or more causes the command to run with a fixed-size thread pool with that many threads. Setting this to 1 causes the command to run sequentially. Setting this to 0 runs the command with a thread pool sized to the number of CPU cores on your machine. Setting this to a negative number runs the command with a fixed-size thread pool equal to the number of CPU cores minus the absolute value of that number. For example, -1 runs the command with (cores-1) threads.
--partition(INCUBATING) The name of the partitions to run the recipe on. If not specified, the recipe will run on all partitions (or the whole repository if there are no partitions).
--recipeThe recipe ID of the recipe that should be run.org.openrewrite.java.search.FindMethods
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--streaming(INCUBATING) Stream results from the recipe run to the console as they are produced. This is intended to be machine readable for the creation of incremental experiences like usage search in the IDE.

mod run-history

Get information about the most recent recipe runs. This will be transitioning to mod audit runs list eventually. A deprecation notice will be added here when we suggest adopting the alternative.

Usage

mod run-history [parameters]

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--json(INCUBATING) Output the run history in JSON. The format of this JSON is unsettled at this point, and the data structuremay change.
--most-recentOnly show the most recent run of each recipe.
--partition(INCUBATING) The name of the partitions to retrieve history on. If not specified, the recipe will retrieve history on all partitions (or the whole repository if there are no partitions).
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite

mod study

Produces studies from OpenRewrite recipe data tables locally.

Data tables are an important part of performing large scale impact analyses on source code.

Usage

mod study [parameters]

Examples

mod study /path/to/project --last-recipe-run --data-table <DATA-TABLE-NAME>

Parameters

NameDescription
pathThe absolute or relative path on disk to a directory containing one or more checked-out Git repositories that you want to operate on. This typically takes the form of targeting a single, checked-out copy of a Git repository or it can be a folder containing a collection of Git repositories that will be discovered by recursively scanning the initial provided directory.

Options

NameDescriptionExample
--csvOutput in CSV format
--data-tableThe name of the data table to study.
--jsonOutput the data table in JSON format with the specified fields. If no value is provided, all columns from the data table will be kept.
--last-recipe-runSelect the ID of the last recipe run. The last recipe run is determined from the whole repository group, not on an individual repository basis.
-o, --output-fileThe location to output the data table.
--recipe-runA recipe run ID listed by mod run-history
--repository-branchRestricts the command to only run against repositories that are currently on this branch.main
--repository-originRestricts the command to only run against repositories that have an origin that matches this.

Supports partial matches (e.g., if the origin is git@github.com:foo/bar - all of the following would match this: github.com:foo/bar, github.com, foo, and foo/bar).
github.com
--repository-pathRestricts the command to only run against repositories that have a path (a combination of the organization/project and the repository name) that matches this.

Supports partial matches (e.g., if the repository is in the foo organization and is called bar - all of the following would match this: foo/bar, foo/.*, foo, and bar).
openrewrite/rewrite
--template

mod generate-completion

Generate bash/zsh completion script for mod.

Usage

mod generate-completion

Options

NameDescription
-V, --versionPrint version information and exit.