Skip to content

Latest commit

 

History

History
1995 lines (1852 loc) · 77.4 KB

optionsref.md

File metadata and controls

1995 lines (1852 loc) · 77.4 KB

Command line options reference

Usage

Usage: octocatalog-diff [command line options]
    -n HOSTNAME1[,HOSTNAME2[,...]],  Use PuppetDB facts from last run of a hostname or a comma separated list of multiple hostnames
        --hostname
        --basedir DIRNAME            Use an alternate base directory (git checkout of puppet repository)
    -f, --from FROM_BRANCH           Branch you are coming from
    -t, --to TO_BRANCH               Branch you are going to
        --from-catalog FILENAME      Use a pre-compiled catalog 'from'
        --to-catalog FILENAME        Use a pre-compiled catalog 'to'
        --bootstrap-script FILENAME  Bootstrap script relative to checkout directory
        --bootstrap-current          Run bootstrap script for the current directory too
        --debug-bootstrap            Print debugging output for bootstrap script
        --bootstrap-environment "key1=val1,key2=val2,..."
                                     Bootstrap script environment variables in key=value format
        --bootstrapped-from-dir DIRNAME
                                     Use a pre-bootstrapped 'from' directory
        --bootstrapped-to-dir DIRNAME
                                     Use a pre-bootstrapped 'to' directory
        --bootstrap-then-exit        Bootstrap from-dir and/or to-dir and then exit
        --[no-]color                 Enable/disable colors in output
    -o, --output-file FILENAME       Output results into FILENAME
        --output-format FORMAT       Output format: text,json,legacy_json
    -d, --[no-]debug                 Print debugging messages to STDERR
    -q, --[no-]quiet                 Quiet (no status messages except errors)
        --ignore "Type1[Title1],Type2[Title2],..."
                                     More resources to ignore in format type[title]
        --[no-]include-tags          Include changes to tags in the diff output
        --fact-file STRING           Override fact globally
        --to-fact-file STRING        Override fact for the to branch
        --from-fact-file STRING      Override fact for the from branch
        --[no-]puppetdb-package-inventory
                                     Include Puppet Enterprise package inventory data, if found
        --save-catalog STRING        Save intermediate catalogs into files globally
        --to-save-catalog STRING     Save intermediate catalogs into files for the to branch
        --from-save-catalog STRING   Save intermediate catalogs into files for the from branch
        --cached-master-dir PATH     Cache bootstrapped origin/master at this path
        --master-cache-branch BRANCH Branch to cache
        --safe-to-delete-cached-master-dir PATH
                                     OK to delete cached master directory at this path
        --hiera-config STRING        Full or relative path to global Hiera configuration file globally
        --to-hiera-config STRING     Full or relative path to global Hiera configuration file for the to branch
        --from-hiera-config STRING   Full or relative path to global Hiera configuration file for the from branch
        --no-hiera-config            Disable hiera config file installation
        --hiera-path STRING          Path to hiera data directory, relative to top directory of repository globally
        --to-hiera-path STRING       Path to hiera data directory, relative to top directory of repository for the to branch
        --from-hiera-path STRING     Path to hiera data directory, relative to top directory of repository for the from branch
        --no-hiera-path              Do not use any default hiera path settings
        --hiera-path-strip STRING    Path prefix to strip when munging hiera.yaml globally
        --to-hiera-path-strip STRING Path prefix to strip when munging hiera.yaml for the to branch
        --from-hiera-path-strip STRING
                                     Path prefix to strip when munging hiera.yaml for the from branch
        --no-hiera-path-strip        Do not use any default hiera path strip settings
        --ignore-attr "attr1,attr2,..."
                                     Attributes to ignore
        --filters FILTER1[,FILTER2[,...]]
                                     Filters to apply
        --[no-]display-source        Show source file and line for each difference
        --[no-]validate-references "before,require,subscribe,notify"
                                     References to validate
        --[no-]compare-file-text[=force]
                                     Compare text, not source location, of file resources
        --storeconfigs-backend TERMINUS
                                     Set the terminus used for storeconfigs
        --[no-]storeconfigs          Enable integration with puppetdb for collected resources
        --retry-failed-catalog N     Retry building a failed catalog N times
        --no-enc                     Disable ENC
        --enc PATH                   Path to ENC script, relative to checkout directory or absolute
        --from-enc PATH              Path to ENC script (for the from catalog only)
        --to-enc PATH                Path to ENC script (for the to catalog only)
        --[no-]display-detail-add    Display parameters and other details for added resources
        --[no-]use-lcs               Use the LCS algorithm to determine differences in arrays
        --[no-]truncate-details      Truncate details with --display-detail-add
        --no-header                  Do not print a header
        --default-header             Print default header with output
        --header STRING              Specify header for output
        --parser PARSER_NAME         Specify parser (default, future)
        --parser-from PARSER_NAME    Specify parser (default, future)
        --parser-to PARSER_NAME      Specify parser (default, future)
        --[no-]display-datatype-changes
                                     Display changes in data type even when strings match
        --[no-]catalog-only          Only compile the catalog for the "to" branch but do not diff
        --[no-]from-puppetdb         Pull "from" catalog from PuppetDB instead of compiling
        --[no-]parallel              Enable or disable parallel processing
        --puppet-binary STRING       Full path to puppet binary globally
        --to-puppet-binary STRING    Full path to puppet binary for the to branch
        --from-puppet-binary STRING  Full path to puppet binary for the from branch
        --puppet-master-token-file STRING
                                     File containing PE RBAC token to authenticate to the Puppetserver API v4 globally
        --to-puppet-master-token-file STRING
                                     File containing PE RBAC token to authenticate to the Puppetserver API v4 for the to branch
        --from-puppet-master-token-file STRING
                                     File containing PE RBAC token to authenticate to the Puppetserver API v4 for the from branch
        --facts-terminus STRING      Facts terminus: one of yaml, facter
        --puppet-master-token STRING PE RBAC token to authenticate to the Puppetserver API v4 globally
        --to-puppet-master-token STRING
                                     PE RBAC token to authenticate to the Puppetserver API v4 for the to branch
        --from-puppet-master-token STRING
                                     PE RBAC token to authenticate to the Puppetserver API v4 for the from branch
        --puppetdb-token TOKEN       Token to access the PuppetDB API
        --puppetdb-token-file PATH   Path containing token for PuppetDB API, relative or absolute
        --puppetdb-url URL           PuppetDB base URL
        --puppetdb-ssl-ca FILENAME   CA certificate that signed the PuppetDB certificate
        --puppetdb-ssl-crl FILENAME  Certificate Revocation List provided by the Puppetserver
        --puppetdb-ssl-client-cert FILENAME
                                     SSL client certificate to connect to PuppetDB
        --puppetdb-ssl-client-key FILENAME
                                     SSL client key to connect to PuppetDB
        --puppetdb-ssl-client-password PASSWORD
                                     Password for SSL client key to connect to PuppetDB
        --puppetdb-ssl-client-password-file FILENAME
                                     Read password for SSL client key from a file
        --puppetdb-api-version N     Version of PuppetDB API (3 or 4)
        --fact-override STRING1[,STRING2[,...]]
                                     Override fact globally
        --to-fact-override STRING1[,STRING2[,...]]
                                     Override fact for the to branch
        --from-fact-override STRING1[,STRING2[,...]]
                                     Override fact for the from branch
        --puppet-master STRING       Hostname or Hostname:PortNumber for Puppet Master globally
        --to-puppet-master STRING    Hostname or Hostname:PortNumber for Puppet Master for the to branch
        --from-puppet-master STRING  Hostname or Hostname:PortNumber for Puppet Master for the from branch
        --puppet-master-api-version STRING
                                     Puppet Master API version (2 for Puppet 3.x, 3 for Puppet 4.x, 4 for Puppet Server >= 6.3.0) globally
        --to-puppet-master-api-version STRING
                                     Puppet Master API version (2 for Puppet 3.x, 3 for Puppet 4.x, 4 for Puppet Server >= 6.3.0) for the to branch
        --from-puppet-master-api-version STRING
                                     Puppet Master API version (2 for Puppet 3.x, 3 for Puppet 4.x, 4 for Puppet Server >= 6.3.0) for the from branch
        --[no-]puppet-master-update-catalog
                                     Update catalog in PuppetDB when using Puppetmaster API version 4 globally
        --[no-]to-puppet-master-update-catalog
                                     Update catalog in PuppetDB when using Puppetmaster API version 4 for the to branch
        --[no-]from-puppet-master-update-catalog
                                     Update catalog in PuppetDB when using Puppetmaster API version 4 for the from branch
        --[no-]puppet-master-update-facts
                                     Update facts in PuppetDB when using Puppetmaster API version 4 globally
        --[no-]to-puppet-master-update-facts
                                     Update facts in PuppetDB when using Puppetmaster API version 4 for the to branch
        --[no-]from-puppet-master-update-facts
                                     Update facts in PuppetDB when using Puppetmaster API version 4 for the from branch
        --puppet-master-ssl-ca STRING
                                     Full path to CA certificate that signed the Puppet Master certificate globally
        --to-puppet-master-ssl-ca STRING
                                     Full path to CA certificate that signed the Puppet Master certificate for the to branch
        --from-puppet-master-ssl-ca STRING
                                     Full path to CA certificate that signed the Puppet Master certificate for the from branch
        --puppet-master-ssl-client-cert STRING
                                     Full path to certificate file for SSL client auth to Puppet Master globally
        --to-puppet-master-ssl-client-cert STRING
                                     Full path to certificate file for SSL client auth to Puppet Master for the to branch
        --from-puppet-master-ssl-client-cert STRING
                                     Full path to certificate file for SSL client auth to Puppet Master for the from branch
        --puppet-master-ssl-client-key STRING
                                     Full path to key file for SSL client auth to Puppet Master globally
        --to-puppet-master-ssl-client-key STRING
                                     Full path to key file for SSL client auth to Puppet Master for the to branch
        --from-puppet-master-ssl-client-key STRING
                                     Full path to key file for SSL client auth to Puppet Master for the from branch
        --enc-override STRING1[,STRING2[,...]]
                                     Override parameter from ENC globally
        --to-enc-override STRING1[,STRING2[,...]]
                                     Override parameter from ENC for the to branch
        --from-enc-override STRING1[,STRING2[,...]]
                                     Override parameter from ENC for the from branch
        --puppet-master-timeout STRING
                                     Puppet Master catalog retrieval timeout in seconds globally
        --to-puppet-master-timeout STRING
                                     Puppet Master catalog retrieval timeout in seconds for the to branch
        --from-puppet-master-timeout STRING
                                     Puppet Master catalog retrieval timeout in seconds for the from branch
        --pe-enc-url URL             Base URL for Puppet Enterprise ENC endpoint
        --pe-enc-token TOKEN         Token to access the Puppet Enterprise ENC API
        --pe-enc-token-file PATH     Path containing token for PE node classifier, relative or absolute
        --pe-enc-ssl-ca FILENAME     CA certificate that signed the ENC API certificate
        --pe-enc-ssl-client-cert FILENAME
                                     SSL client certificate to connect to PE ENC
        --pe-enc-ssl-client-key FILENAME
                                     SSL client key to connect to PE ENC
        --override-script-path DIRNAME
                                     Directory with scripts to override built-ins
        --no-ignore-tags             Disable ignoring based on tags
        --ignore-tags STRING1[,STRING2[,...]]
                                     Specify tags to ignore
        --compare-file-text-ignore-tags STRING1[,STRING2[,...]]
                                     Tags that exclude a file resource from text comparison
        --[no-]preserve-environments Enable or disable environment preservation
        --environment STRING         Environment for catalog compilation globally
        --to-environment STRING      Environment for catalog compilation for the to branch
        --from-environment STRING    Environment for catalog compilation for the from branch
        --create-symlinks STRING1[,STRING2[,...]]
                                     Symlinks to create globally
        --to-create-symlinks STRING1[,STRING2[,...]]
                                     Symlinks to create for the to branch
        --from-create-symlinks STRING1[,STRING2[,...]]
                                     Symlinks to create for the from branch
        --command-line STRING1[,STRING2[,...]]
                                     Command line arguments globally
        --to-command-line STRING1[,STRING2[,...]]
                                     Command line arguments for the to branch
        --from-command-line STRING1[,STRING2[,...]]
                                     Command line arguments for the from branch
        --pass-env-vars VAR1[,VAR2[,...]]
                                     Environment variables to pass
        --[no-]suppress-absent-file-details
                                     Suppress certain attributes of absent files

Detailed options description

Option Description Extended Description
--basedir DIRNAME
Use an alternate base directory (git checkout of puppet repository) Option to set the base checkout directory of puppet repository (basedir.rb)
--bootstrap-current 
Run bootstrap script for the current directory too Option to bootstrap the current directory (by default, the bootstrap script is NOT run when the catalog builds in the current directory). (bootstrap_current.rb)
--bootstrap-environment "key1=val1,key2=val2,..."
Bootstrap script environment variables in key=value format Allow the bootstrap environment to be set up via the command line. (bootstrap_environment.rb)
--bootstrap-script FILENAME
Bootstrap script relative to checkout directory Allow specification of a bootstrap script. This runs after checking out the directory, and before running puppet there. Good for running librarian to install modules, and anything else site-specific that needs to be done. (bootstrap_script.rb)
--bootstrap-then-exit 
Bootstrap from-dir and/or to-dir and then exit Option to bootstrap directories and then exit (bootstrap_then_exit.rb)
--bootstrapped-from-dir DIRNAME
Use a pre-bootstrapped 'from' directory Allow (or create) directories that are already bootstrapped. Handy to allow "bootstrap once, build many" to save time when diffing multiple catalogs on this system. (bootstrapped_dirs.rb)
--bootstrapped-to-dir DIRNAME
Use a pre-bootstrapped 'to' directory Allow (or create) directories that are already bootstrapped. Handy to allow "bootstrap once, build many" to save time when diffing multiple catalogs on this system. (bootstrapped_dirs.rb)
--cached-master-dir PATH
Cache bootstrapped origin/master at this path Cache a bootstrapped checkout of 'master' and use that for time-saving when the SHA has not changed. (cached_master_dir.rb)
--catalog-only
--no-catalog-only 
Only compile the catalog for the "to" branch but do not diff When set, --catalog-only will only compile the catalog for the 'to' branch, and skip any diffing activity. The catalog will be printed to STDOUT or written to the output file. (catalog_only.rb)
--color
--no-color 
Enable/disable colors in output Color printing option (color.rb)
--command-line STRING1[,STRING2[,...]]
Command line arguments globally Provide additional command line flags to set when running Puppet to compile catalogs. (command_line.rb)
--compare-file-text
--no-compare-file-text 
Compare text, not source location, of file resources When a file is specified with `source => 'puppet:///modules/something/foo.txt'`, remove the 'source' attribute and populate the 'content' attribute with the text of the file. This allows for a diff of the content, rather than a diff of the location, which is what is most often desired. This has historically been a binary option, so --compare-file-text with no argument will set this to `true` and --no-compare-file-text will set this to `false`. Note that --no-compare-file-text does not accept an argument. File text comparison will be auto-disabled in circumstances other than compiling and comparing two catalogs. To force file text comparison to be enabled at other times, set --compare-file-text=force. This allows the content of the file to be substituted in to --catalog-only compilations, for example. (compare_file_text.rb)
--compare-file-text-ignore-tags STRING1[,STRING2[,...]]
Tags that exclude a file resource from text comparison When a file is specified with `source => 'puppet:///modules/something/foo.txt'`, remove the 'source' attribute and populate the 'content' attribute with the text of the file. This allows for a diff of the content, rather than a diff of the location, which is what is most often desired. This has historically been a binary option, so --compare-file-text with no argument will set this to `true` and --no-compare-file-text will set this to `false`. Note that --no-compare-file-text does not accept an argument. File text comparison will be auto-disabled in circumstances other than compiling and comparing two catalogs. To force file text comparison to be enabled at other times, set --compare-file-text=force. This allows the content of the file to be substituted in to --catalog-only compilations, for example. (compare_file_text.rb)
--create-symlinks STRING1[,STRING2[,...]]
Symlinks to create globally Specify which directories from the base should be symlinked into the temporary compilation environment. This is useful only in conjunction with `--preserve-environments`. (create_symlinks.rb)
-d
--debug
--no-debug 
Print debugging messages to STDERR Debugging option (debug.rb)
--debug-bootstrap 
Print debugging output for bootstrap script Option to print debugging output for the bootstrap script in addition to the normal debugging output. Note that `--debug` must also be enabled for this option to have any effect. (debug_bootstrap.rb)
--default-header 
Print default header with output Provide ability to set custom header or to display no header at all (header.rb)
--display-datatype-changes
--no-display-datatype-changes 
Display changes in data type even when strings match Toggle on or off the display of data type changes when the string representation is the same. For example with this enabled, '42' (the string) and 42 (the integer) will be displayed as a difference. With this disabled, this is not displayed as a difference. (display_datatype_changes.rb)
--display-detail-add
--no-display-detail-add 
Display parameters and other details for added resources Provide ability to display details of 'added' resources in the output. (display_detail_add.rb)
--display-source
--no-display-source 
Show source file and line for each difference Display source filename and line number for diffs (display_source_file_line.rb)
--enc PATH
Path to ENC script, relative to checkout directory or absolute Path to external node classifier, relative to the base directory of the checkout. (enc.rb)
--enc-override STRING1[,STRING2[,...]]
Override parameter from ENC globally Allow override of ENC parameters on the command line. ENC parameter overrides can be supplied for the 'to' or 'from' catalog, or for both. There is some attempt to handle data types here (since all items on the command line are strings) by permitting a data type specification as well. For parameters nested in hashes, use `::` as the delimiter. (enc_override.rb)
--environment STRING
Environment for catalog compilation globally Specify the environment to use when compiling the catalog. This is useful only in conjunction with `--preserve-environments`. (environment.rb)
--fact-file STRING
Override fact globally Allow an existing fact file to be provided, to avoid pulling facts from PuppetDB. (fact_file.rb)
--fact-override STRING1[,STRING2[,...]]
Override fact globally Allow override of facts on the command line. Fact overrides can be supplied for the 'to' or 'from' catalog, or for both. There is some attempt to handle data types here (since all items on the command line are strings) by permitting a data type specification as well. (fact_override.rb)
--facts-terminus STRING
Facts terminus: one of yaml, facter Get the facts terminus. Generally this is 'yaml' and a fact file will be loaded from PuppetDB or elsewhere in the environment. However it can be set to 'facter' which will run facter on the host on which this is running. (facts_terminus.rb)
--filters FILTER1[,FILTER2[,...]]
Filters to apply Specify one or more filters to apply to the results of the catalog difference. For a list of available filters and further explanation, please refer to Filtering results. (filters.rb)
-f FROM_BRANCH
--from FROM_BRANCH
Branch you are coming from Set the 'from' and 'to' branches, which is used to compile catalogs. A branch of '.' means to use the current contents of the base code directory without any git checkouts. (to_from_branch.rb)
--from-catalog FILENAME
Use a pre-compiled catalog 'from' If pre-compiled catalogs are available, these can be used to short-circuit the build process. These files must exist and be in Puppet catalog format. (existing_catalogs.rb)
--from-command-line STRING1[,STRING2[,...]]
Command line arguments for the from branch Provide additional command line flags to set when running Puppet to compile catalogs. (command_line.rb)
--from-create-symlinks STRING1[,STRING2[,...]]
Symlinks to create for the from branch Specify which directories from the base should be symlinked into the temporary compilation environment. This is useful only in conjunction with `--preserve-environments`. (create_symlinks.rb)
--from-enc PATH
Path to ENC script (for the from catalog only) Path to external node classifier, relative to the base directory of the checkout. (enc.rb)
--from-enc-override STRING1[,STRING2[,...]]
Override parameter from ENC for the from branch Allow override of ENC parameters on the command line. ENC parameter overrides can be supplied for the 'to' or 'from' catalog, or for both. There is some attempt to handle data types here (since all items on the command line are strings) by permitting a data type specification as well. For parameters nested in hashes, use `::` as the delimiter. (enc_override.rb)
--from-environment STRING
Environment for catalog compilation for the from branch Specify the environment to use when compiling the catalog. This is useful only in conjunction with `--preserve-environments`. (environment.rb)
--from-fact-file STRING
Override fact for the from branch Allow an existing fact file to be provided, to avoid pulling facts from PuppetDB. (fact_file.rb)
--from-fact-override STRING1[,STRING2[,...]]
Override fact for the from branch Allow override of facts on the command line. Fact overrides can be supplied for the 'to' or 'from' catalog, or for both. There is some attempt to handle data types here (since all items on the command line are strings) by permitting a data type specification as well. (fact_override.rb)
--from-hiera-config STRING
Full or relative path to global Hiera configuration file for the from branch Specify a relative path to the Hiera yaml file (hiera_config.rb)
--from-hiera-path STRING
Path to hiera data directory, relative to top directory of repository for the from branch Specify the path to the Hiera data directory (relative to the top level Puppet checkout). For Puppet Enterprise and the Puppet control repo template, the value of this should be 'hieradata', which is the default. (hiera_path.rb)
--from-hiera-path-strip STRING
Path prefix to strip when munging hiera.yaml for the from branch Specify the path to strip off the datadir to munge hiera.yaml file (hiera_path_strip.rb)
--from-puppet-binary STRING
Full path to puppet binary for the from branch Set --puppet-binary, --to-puppet-binary, --from-puppet-binary (puppet_binary.rb)
--from-puppet-master STRING
Hostname or Hostname:PortNumber for Puppet Master for the from branch Specify the hostname, or hostname:port, for the Puppet Master. (puppet_master.rb)
--from-puppet-master-api-version STRING
Puppet Master API version (2 for Puppet 3.x, 3 for Puppet 4.x, 4 for Puppet Server >= 6.3.0) for the from branch Specify the API version to use for the Puppet Master. This makes it possible to authenticate to a version 3.x PuppetMaster by specifying the API version as 2, or for a version 4.x PuppetMaster by specifying API version as 3. (puppet_master_api_version.rb)
--from-puppet-master-ssl-ca STRING
Full path to CA certificate that signed the Puppet Master certificate for the from branch Specify the CA certificate for Puppet Master. If specified, this will enable SSL verification that the certificate being presented has been signed by this CA, and that the common name matches the name you are using to connecting. (puppet_master_ssl_ca.rb)
--from-puppet-master-ssl-client-cert STRING
Full path to certificate file for SSL client auth to Puppet Master for the from branch Specify the SSL client certificate for Puppet Master. This makes it possible to authenticate with a client certificate keypair to the Puppet Master. (puppet_master_ssl_client_cert.rb)
--from-puppet-master-ssl-client-key STRING
Full path to key file for SSL client auth to Puppet Master for the from branch Specify the SSL client key for Puppet Master. This makes it possible to authenticate with a client certificate keypair to the Puppet Master. (puppet_master_ssl_client_key.rb)
--from-puppet-master-timeout STRING
Puppet Master catalog retrieval timeout in seconds for the from branch Specify a timeout for retrieving a catalog from a Puppet master / Puppet server. This timeout is specified in seconds. (puppet_master_timeout.rb)
--from-puppet-master-token STRING
PE RBAC token to authenticate to the Puppetserver API v4 for the from branch Specify a PE RBAC token used to authenticate to Puppetserver for v4 catalog API calls. (puppet_master_token.rb)
--from-puppet-master-token-file STRING
File containing PE RBAC token to authenticate to the Puppetserver API v4 for the from branch Specify a path to a file containing a PE RBAC token used to authenticate to the Puppetserver for a v4 catalog API call. (puppet_master_token_file.rb)
--from-puppetdb
--no-from-puppetdb 
Pull "from" catalog from PuppetDB instead of compiling Set --from-puppetdb to pull most recent catalog from PuppetDB instead of compiling (from_puppetdb.rb)
--from-save-catalog STRING
Save intermediate catalogs into files for the from branch Allow catalogs to be saved to a file before they are diff'd. (save_catalog.rb)
--header STRING
Specify header for output Provide ability to set custom header or to display no header at all (header.rb)
--hiera-config STRING
Full or relative path to global Hiera configuration file globally Specify a relative path to the Hiera yaml file (hiera_config.rb)
--hiera-path STRING
Path to hiera data directory, relative to top directory of repository globally Specify the path to the Hiera data directory (relative to the top level Puppet checkout). For Puppet Enterprise and the Puppet control repo template, the value of this should be 'hieradata', which is the default. (hiera_path.rb)
--hiera-path-strip STRING
Path prefix to strip when munging hiera.yaml globally Specify the path to strip off the datadir to munge hiera.yaml file (hiera_path_strip.rb)
-n HOSTNAME1[,HOSTNAME2[,...]]
--hostname HOSTNAME1[,HOSTNAME2[,...]]
Use PuppetDB facts from last run of a hostname or a comma separated list of multiple hostnames Set hostname, which is used to look up facts in PuppetDB, and in the header of diff display. This option can recieve a single hostname, or a comma separated list of multiple hostnames, which are split into an Array. Multiple hostnames do not work with the `catalog-only` or `bootstrap-then-exit` options. (hostname.rb)
--ignore "Type1[Title1],Type2[Title2],..."
More resources to ignore in format type[title] Options used when comparing catalogs - set ignored changes. (ignore.rb)
--ignore-attr "attr1,attr2,..."
Attributes to ignore Specify attributes to ignore (ignore_attr.rb)
--ignore-tags STRING1[,STRING2[,...]]
Specify tags to ignore Provide ability to set one or more tags, which will cause catalog-diff to ignore any changes for any defined type where this tag is set. (ignore_tags.rb)
--include-tags
--no-include-tags 
Include changes to tags in the diff output Options used when comparing catalogs - tags are generally ignored; you can un-ignore them. (include_tags.rb)
--master-cache-branch BRANCH
Branch to cache Allow override of the branch that is cached. This defaults to 'origin/master'. (master_cache_branch.rb)
--no-enc 
Disable ENC Path to external node classifier, relative to the base directory of the checkout. (enc.rb)
--no-header 
Do not print a header Provide ability to set custom header or to display no header at all (header.rb)
--no-hiera-config 
Disable hiera config file installation Specify a relative path to the Hiera yaml file (hiera_config.rb)
--no-hiera-path 
Do not use any default hiera path settings Specify the path to the Hiera data directory (relative to the top level Puppet checkout). For Puppet Enterprise and the Puppet control repo template, the value of this should be 'hieradata', which is the default. (hiera_path.rb)
--no-hiera-path-strip 
Do not use any default hiera path strip settings Specify the path to strip off the datadir to munge hiera.yaml file (hiera_path_strip.rb)
--no-ignore-tags 
Disable ignoring based on tags Provide ability to set one or more tags, which will cause catalog-diff to ignore any changes for any defined type where this tag is set. (ignore_tags.rb)
-o FILENAME
--output-file FILENAME
Output results into FILENAME Output file option (output_file.rb)
--output-format FORMAT
Output format: text,json,legacy_json Output format option. 'text' is human readable text, 'json' is an array of differences identified by human readable keys (the preferred octocatalog-diff 1.x format), and 'legacy_json' is an array of differences, where each difference is an array (the octocatalog-diff 0.x format). (output_format.rb)
--override-script-path DIRNAME
Directory with scripts to override built-ins Provide an optional directory to override default built-in scripts such as git checkout and puppet version determination. (override_script_path.rb)
--parallel
--no-parallel 
Enable or disable parallel processing Disable or enable parallel processing of catalogs. (parallel.rb)
--parser PARSER_NAME
Specify parser (default, future) Enable future parser for both branches or for just one (parser.rb)
--parser-from PARSER_NAME
Specify parser (default, future) Enable future parser for both branches or for just one (parser.rb)
--parser-to PARSER_NAME
Specify parser (default, future) Enable future parser for both branches or for just one (parser.rb)
--pass-env-vars VAR1[,VAR2[,...]]
Environment variables to pass One or more environment variables that should be made available to the Puppet binary when parsing the catalog. For example, --pass-env-vars FOO,BAR will make the FOO and BAR environment variables available. Setting these variables is your responsibility outside of octocatalog-diff. (pass_env_vars.rb)
--pe-enc-ssl-ca FILENAME
CA certificate that signed the ENC API certificate Specify the CA certificate for the Puppet Enterprise ENC. If specified, this will enable SSL verification that the certificate being presented has been signed by this CA, and that the common name matches the name you are using to connecting. (pe_enc_ssl_ca.rb)
--pe-enc-ssl-client-cert FILENAME
SSL client certificate to connect to PE ENC Specify the client certificate for connecting to the Puppet Enterprise ENC. This must be specified along with --pe-enc-ssl-client-key in order to work. (pe_enc_ssl_client_cert.rb)
--pe-enc-ssl-client-key FILENAME
SSL client key to connect to PE ENC Specify the client key for connecting to Puppet Enterprise ENC. This must be specified along with --pe-enc-ssl-client-cert in order to work. (pe_enc_ssl_client_key.rb)
--pe-enc-token TOKEN
Token to access the Puppet Enterprise ENC API Specify the access token to access the Puppet Enterprise ENC. Refer to https://docs.puppet.com/pe/latest/nc_forming_requests.html#authentication for details on generating and obtaining a token. Use this option to specify the text of the token. (Use --pe-enc-token-file to read the content of the token from a file.) (pe_enc_token.rb)
--pe-enc-token-file PATH
Path containing token for PE node classifier, relative or absolute Specify the access token to access the Puppet Enterprise ENC. Refer to https://docs.puppet.com/pe/latest/nc_forming_requests.html#authentication for details on generating and obtaining a token. Use this option if the token is stored in a file, to read the content of the token from the file. (pe_enc_token_file.rb)
--pe-enc-url URL
Base URL for Puppet Enterprise ENC endpoint Specify the URL to the Puppet Enterprise ENC API. By default, the node classifier service listens on port 4433 and all endpoints are relative to the /classifier-api/ path. That means the likely value for this option will be something like: https://your-pe-console-server:4433/classifier-api (pe_enc_url.rb)
--preserve-environments
--no-preserve-environments 
Enable or disable environment preservation Preserve the `environments` directory from the repository when compiling the catalog. Likely requires some combination of `--to-environment`, `--from-environment`, and/or `--create-symlinks` to work correctly. (preserve_environments.rb)
--puppet-binary STRING
Full path to puppet binary globally Set --puppet-binary, --to-puppet-binary, --from-puppet-binary (puppet_binary.rb)
--puppet-master STRING
Hostname or Hostname:PortNumber for Puppet Master globally Specify the hostname, or hostname:port, for the Puppet Master. (puppet_master.rb)
--puppet-master-api-version STRING
Puppet Master API version (2 for Puppet 3.x, 3 for Puppet 4.x, 4 for Puppet Server >= 6.3.0) globally Specify the API version to use for the Puppet Master. This makes it possible to authenticate to a version 3.x PuppetMaster by specifying the API version as 2, or for a version 4.x PuppetMaster by specifying API version as 3. (puppet_master_api_version.rb)
--puppet-master-ssl-ca STRING
Full path to CA certificate that signed the Puppet Master certificate globally Specify the CA certificate for Puppet Master. If specified, this will enable SSL verification that the certificate being presented has been signed by this CA, and that the common name matches the name you are using to connecting. (puppet_master_ssl_ca.rb)
--puppet-master-ssl-client-cert STRING
Full path to certificate file for SSL client auth to Puppet Master globally Specify the SSL client certificate for Puppet Master. This makes it possible to authenticate with a client certificate keypair to the Puppet Master. (puppet_master_ssl_client_cert.rb)
--puppet-master-ssl-client-key STRING
Full path to key file for SSL client auth to Puppet Master globally Specify the SSL client key for Puppet Master. This makes it possible to authenticate with a client certificate keypair to the Puppet Master. (puppet_master_ssl_client_key.rb)
--puppet-master-timeout STRING
Puppet Master catalog retrieval timeout in seconds globally Specify a timeout for retrieving a catalog from a Puppet master / Puppet server. This timeout is specified in seconds. (puppet_master_timeout.rb)
--puppet-master-token STRING
PE RBAC token to authenticate to the Puppetserver API v4 globally Specify a PE RBAC token used to authenticate to Puppetserver for v4 catalog API calls. (puppet_master_token.rb)
--puppet-master-token-file STRING
File containing PE RBAC token to authenticate to the Puppetserver API v4 globally Specify a path to a file containing a PE RBAC token used to authenticate to the Puppetserver for a v4 catalog API call. (puppet_master_token_file.rb)
--puppetdb-api-version N
Version of PuppetDB API (3 or 4) Specify the API version to use for the PuppetDB. The current values supported are '3' or '4', and '4' is the default. (puppetdb_api_version.rb)
--puppetdb-package-inventory
--no-puppetdb-package-inventory 
Include Puppet Enterprise package inventory data, if found When pulling facts from PuppetDB in a Puppet Enterprise environment, also include the Puppet Enterprise Package Inventory data in the fact results, if available. Generally you should not need to specify this, but including the package inventory data will produce a more accurate set of input facts for environments using package inventory. (puppetdb_package_inventory.rb)
--puppetdb-ssl-ca FILENAME
CA certificate that signed the PuppetDB certificate Specify the CA certificate for PuppetDB. If specified, this will enable SSL verification that the certificate being presented has been signed by this CA, and that the common name matches the name you are using to connecting. (puppetdb_ssl_ca.rb)
--puppetdb-ssl-client-cert FILENAME
SSL client certificate to connect to PuppetDB Specify the client certificate for connecting to PuppetDB. This must be specified along with --puppetdb-ssl-client-key in order to work. (puppetdb_ssl_client_cert.rb)
--puppetdb-ssl-client-key FILENAME
SSL client key to connect to PuppetDB Specify the client key for connecting to PuppetDB. This must be specified along with --puppetdb-ssl-client-cert in order to work. (puppetdb_ssl_client_key.rb)
--puppetdb-ssl-client-password PASSWORD
Password for SSL client key to connect to PuppetDB Specify the password for a PEM or PKCS12 private key on the command line. Note that `--puppetdb-ssl-client-password-file` is slightly more secure because the text of the password won't appear in the process list. (puppetdb_ssl_client_password.rb)
--puppetdb-ssl-client-password-file FILENAME
Read password for SSL client key from a file Specify the password for a PEM or PKCS12 private key, by reading it from a file. (puppetdb_ssl_client_password_file.rb)
--puppetdb-ssl-crl FILENAME
Certificate Revocation List provided by the Puppetserver Specify the Certificate Revocation List for PuppetDB SSL. (puppetdb_ssl_crl.rb)
--puppetdb-token TOKEN
Token to access the PuppetDB API Specify the PE RBAC token to access the PuppetDB API. Refer to https://puppet.com/docs/pe/latest/rbac/rbac_token_auth_intro.html#generate-a-token-using-puppet-access for details on generating and obtaining a token. Use this option to specify the text of the token. (Use --puppetdb-token-file to read the content of the token from a file.) (puppetdb_token.rb)
--puppetdb-token-file PATH
Path containing token for PuppetDB API, relative or absolute Specify the PE RBAC token to access the PuppetDB API. Refer to https://puppet.com/docs/pe/latest/rbac/rbac_token_auth_intro.html#generate-a-token-using-puppet-access for details on generating and obtaining a token. Use this option to specify the text in a file, to read the content of the token from the file. (puppetdb_token_file.rb)
--puppetdb-url URL
PuppetDB base URL Specify the base URL for PuppetDB. This will generally look like https://puppetdb.yourdomain.com:8081 (puppetdb_url.rb)
-q
--quiet
--no-quiet 
Quiet (no status messages except errors) Quiet option (quiet.rb)
--retry-failed-catalog N
Retry building a failed catalog N times Transient errors can cause catalog compilation problems. This adds an option to retry a failed catalog multiple times before kicking out an error message. (retry_failed_catalog.rb)
--safe-to-delete-cached-master-dir PATH
OK to delete cached master directory at this path By specifying a directory path here, you are explicitly giving permission to the program to delete it if it believes it needs to be created (e.g., if the SHA has changed of the cached directory). (safe_to_delete_cached_master_dir.rb)
--save-catalog STRING
Save intermediate catalogs into files globally Allow catalogs to be saved to a file before they are diff'd. (save_catalog.rb)
--storeconfigs
--no-storeconfigs 
Enable integration with puppetdb for collected resources Set storeconfigs (integration with PuppetDB for collected resources) (storeconfigs.rb)
--storeconfigs-backend TERMINUS
Set the terminus used for storeconfigs Set storeconfigs (integration with PuppetDB for collected resources) (storeconfigs_backend.rb)
--suppress-absent-file-details
--no-suppress-absent-file-details 
Suppress certain attributes of absent files If enabled, this option will suppress changes to certain attributes of a file, if the file is specified to be 'absent' in the target catalog. Suppressed changes in this case include user, group, mode, and content, because a removed file has none of those. This option is DEPRECATED; please use --filters AbsentFile instead. (suppress_absent_file_details.rb)
-t TO_BRANCH
--to TO_BRANCH
Branch you are going to Set the 'from' and 'to' branches, which is used to compile catalogs. A branch of '.' means to use the current contents of the base code directory without any git checkouts. (to_from_branch.rb)
--to-catalog FILENAME
Use a pre-compiled catalog 'to' If pre-compiled catalogs are available, these can be used to short-circuit the build process. These files must exist and be in Puppet catalog format. (existing_catalogs.rb)
--to-command-line STRING1[,STRING2[,...]]
Command line arguments for the to branch Provide additional command line flags to set when running Puppet to compile catalogs. (command_line.rb)
--to-create-symlinks STRING1[,STRING2[,...]]
Symlinks to create for the to branch Specify which directories from the base should be symlinked into the temporary compilation environment. This is useful only in conjunction with `--preserve-environments`. (create_symlinks.rb)
--to-enc PATH
Path to ENC script (for the to catalog only) Path to external node classifier, relative to the base directory of the checkout. (enc.rb)
--to-enc-override STRING1[,STRING2[,...]]
Override parameter from ENC for the to branch Allow override of ENC parameters on the command line. ENC parameter overrides can be supplied for the 'to' or 'from' catalog, or for both. There is some attempt to handle data types here (since all items on the command line are strings) by permitting a data type specification as well. For parameters nested in hashes, use `::` as the delimiter. (enc_override.rb)
--to-environment STRING
Environment for catalog compilation for the to branch Specify the environment to use when compiling the catalog. This is useful only in conjunction with `--preserve-environments`. (environment.rb)
--to-fact-file STRING
Override fact for the to branch Allow an existing fact file to be provided, to avoid pulling facts from PuppetDB. (fact_file.rb)
--to-fact-override STRING1[,STRING2[,...]]
Override fact for the to branch Allow override of facts on the command line. Fact overrides can be supplied for the 'to' or 'from' catalog, or for both. There is some attempt to handle data types here (since all items on the command line are strings) by permitting a data type specification as well. (fact_override.rb)
--to-hiera-config STRING
Full or relative path to global Hiera configuration file for the to branch Specify a relative path to the Hiera yaml file (hiera_config.rb)
--to-hiera-path STRING
Path to hiera data directory, relative to top directory of repository for the to branch Specify the path to the Hiera data directory (relative to the top level Puppet checkout). For Puppet Enterprise and the Puppet control repo template, the value of this should be 'hieradata', which is the default. (hiera_path.rb)
--to-hiera-path-strip STRING
Path prefix to strip when munging hiera.yaml for the to branch Specify the path to strip off the datadir to munge hiera.yaml file (hiera_path_strip.rb)
--to-puppet-binary STRING
Full path to puppet binary for the to branch Set --puppet-binary, --to-puppet-binary, --from-puppet-binary (puppet_binary.rb)
--to-puppet-master STRING
Hostname or Hostname:PortNumber for Puppet Master for the to branch Specify the hostname, or hostname:port, for the Puppet Master. (puppet_master.rb)
--to-puppet-master-api-version STRING
Puppet Master API version (2 for Puppet 3.x, 3 for Puppet 4.x, 4 for Puppet Server >= 6.3.0) for the to branch Specify the API version to use for the Puppet Master. This makes it possible to authenticate to a version 3.x PuppetMaster by specifying the API version as 2, or for a version 4.x PuppetMaster by specifying API version as 3. (puppet_master_api_version.rb)
--to-puppet-master-ssl-ca STRING
Full path to CA certificate that signed the Puppet Master certificate for the to branch Specify the CA certificate for Puppet Master. If specified, this will enable SSL verification that the certificate being presented has been signed by this CA, and that the common name matches the name you are using to connecting. (puppet_master_ssl_ca.rb)
--to-puppet-master-ssl-client-cert STRING
Full path to certificate file for SSL client auth to Puppet Master for the to branch Specify the SSL client certificate for Puppet Master. This makes it possible to authenticate with a client certificate keypair to the Puppet Master. (puppet_master_ssl_client_cert.rb)
--to-puppet-master-ssl-client-key STRING
Full path to key file for SSL client auth to Puppet Master for the to branch Specify the SSL client key for Puppet Master. This makes it possible to authenticate with a client certificate keypair to the Puppet Master. (puppet_master_ssl_client_key.rb)
--to-puppet-master-timeout STRING
Puppet Master catalog retrieval timeout in seconds for the to branch Specify a timeout for retrieving a catalog from a Puppet master / Puppet server. This timeout is specified in seconds. (puppet_master_timeout.rb)
--to-puppet-master-token STRING
PE RBAC token to authenticate to the Puppetserver API v4 for the to branch Specify a PE RBAC token used to authenticate to Puppetserver for v4 catalog API calls. (puppet_master_token.rb)
--to-puppet-master-token-file STRING
File containing PE RBAC token to authenticate to the Puppetserver API v4 for the to branch Specify a path to a file containing a PE RBAC token used to authenticate to the Puppetserver for a v4 catalog API call. (puppet_master_token_file.rb)
--to-save-catalog STRING
Save intermediate catalogs into files for the to branch Allow catalogs to be saved to a file before they are diff'd. (save_catalog.rb)
--truncate-details
--no-truncate-details 
Truncate details with --display-detail-add When using `--display-detail-add` by default the details of any field will be truncated at 80 characters. Specify `--no-truncate-details` to display the full output. This option has no effect when `--display-detail-add` is not used. (truncate_details.rb)
--use-lcs
--no-use-lcs 
Use the LCS algorithm to determine differences in arrays Configures using the Longest common subsequence (LCS) algorithm to determine differences in arrays (use_lcs.rb)
--validate-references
--no-validate-references 
References to validate Confirm that each `before`, `require`, `subscribe`, and/or `notify` points to a valid resource in the catalog. This value should be specified as an array of which of these parameters are to be checked. (validate_references.rb)

Using these options in API calls

Most of these options can also be used when making calls to the API.

Generally, parameters for the API are named corresponding to the names of the command line parameters, with dashes (-) converted to underscores (_). For example, the command line option --hiera-config is passed to the API as the symbol :hiera_config.

Each of the options above has a link to the source file where it is declared, should you wish to review the specific parameter names and data structures that are being set.