Eclipse Che® CLI
Issues are tracked on the main Eclipse Che® Repository: https://github.com/eclipse/che/issues
There are two channels of chectl: stable and next
Stable is for all tagged versions of Eclipse Che®. Next is updated after each commit/Pull Request being merged in main branch of the Chectl repository.
If you're using Windows x64, here is how to install chectl by using one single PowerShell command:
- For stablechannel:
C:\Users> Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://che-incubator.github.io/chectl/install.ps1'))
- For nextchannel:
C:\Users> $CHANNEL="next"; Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://che-incubator.github.io/chectl/install.ps1'))
If you're using linux or macOS, here is how to install chectl by using one single command:
- For stablechannel:
$ bash <(curl -sL  https://che-incubator.github.io/chectl/install.sh)
- For nextchannel:
$ bash <(curl -sL  https://che-incubator.github.io/chectl/install.sh) --channel=next
Manual install:
- Download a .tgz file based on your Operating System / Arch from https://github.com/che-incubator/chectl/releases
- Unpack the assembly
- Move chectlfolder into a folder like$HOME/chectl
- Add alias alias chectl=$HOME/chectl/bin/run
- Download a .tgz file based on your Operating System / Arch from https://github.com/che-incubator/chectl/releases
- Unpack the assembly into a local repository
CHECTL_VERSION=<DOWNLOADED_CHECTL_VERSION>
CHECTL_BINARIES=<DOWNLOADED_BINARIES_PATH>
CLIENT_DIR=${XDG_DATA_HOME:="$(cd && pwd)/.local/share"}/chectl/client/${CHECTL_VERSION}
mkdir ${CLIENT_DIR} -p
tar -xzf ${CHECTL_BINARIES} -C ${CLIENT_DIR} --strip-components=1- Update chectlfrom the local repositorychectl update --from-localby prompting the downloaded version
$ chectl server:start
running command...
$ chectl server:stop
running command...
$ chectl --help [COMMAND]
USAGE
  $ chectl COMMAND
...- chectl autocomplete [SHELL]
- chectl cacert:export
- chectl commands
- chectl dashboard:open
- chectl help [COMMANDS]
- chectl server:debug
- chectl server:delete
- chectl server:deploy
- chectl server:logs
- chectl server:start
- chectl server:status
- chectl server:stop
- chectl server:update
- chectl update [CHANNEL]
- chectl version
display autocomplete installation instructions
USAGE
  $ chectl autocomplete [SHELL] [-r]
ARGUMENTS
  SHELL  (zsh|bash|powershell) Shell type
FLAGS
  -r, --refresh-cache  Refresh cache (ignores displaying instructions)
DESCRIPTION
  display autocomplete installation instructions
EXAMPLES
  $ chectl autocomplete
  $ chectl autocomplete bash
  $ chectl autocomplete zsh
  $ chectl autocomplete powershell
  $ chectl autocomplete --refresh-cache
See code: @oclif/plugin-autocomplete
Retrieves Eclipse Che self-signed certificate
USAGE
  $ chectl cacert:export [-h] [-n <value>] [--telemetry on|off] [-d <value>]
FLAGS
  -d, --destination=<value>
      Destination where to store Eclipse Che self-signed CA certificate.
      If the destination is a file (might not exist), then the certificate will be saved there in PEM format.
      If the destination is a directory, then cheCA.crt file will be created there with Eclipse Che certificate in PEM
      format.
      If this option is omitted, then Eclipse Che certificate will be stored in a user's temporary directory as cheCA.crt.
  -h, --help
      Show CLI help.
  -n, --chenamespace=<value>
      Eclipse Che Kubernetes namespace.
  --telemetry=<option>
      Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
      <options: on|off>
DESCRIPTION
  Retrieves Eclipse Che self-signed certificate
See code: src/commands/cacert/export.ts
list all the commands
USAGE
  $ chectl commands [--json] [-h] [--hidden] [--tree] [--columns <value> | -x] [--filter <value>] [--no-header
    | [--csv | --no-truncate]] [--output csv|json|yaml |  | ] [--sort <value>]
FLAGS
  -h, --help         Show CLI help.
  -x, --extended     show extra columns
  --columns=<value>  only show provided columns (comma-separated)
  --csv              output is csv format [alias: --output=csv]
  --filter=<value>   filter property by partial string matching, ex: name=foo
  --hidden           show hidden commands
  --no-header        hide table header from output
  --no-truncate      do not truncate output to fit screen
  --output=<option>  output in a more machine friendly format
                     <options: csv|json|yaml>
  --sort=<value>     property to sort by (prepend '-' for descending)
  --tree             show tree of commands
GLOBAL FLAGS
  --json  Format output as json.
DESCRIPTION
  list all the commands
See code: @oclif/plugin-commands
Open Eclipse Che dashboard
USAGE
  $ chectl dashboard:open [-h] [-n <value>] [--telemetry on|off]
FLAGS
  -h, --help                  Show CLI help.
  -n, --chenamespace=<value>  Eclipse Che Kubernetes namespace.
  --telemetry=<option>        Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
                              <options: on|off>
DESCRIPTION
  Open Eclipse Che dashboard
See code: src/commands/dashboard/open.ts
Display help for chectl.
USAGE
  $ chectl help [COMMANDS] [-n]
ARGUMENTS
  COMMANDS  Command to show help for.
FLAGS
  -n, --nested-commands  Include all nested commands in the output.
DESCRIPTION
  Display help for chectl.
See code: @oclif/plugin-help
Enable local debug of Eclipse Che server
USAGE
  $ chectl server:debug [-h] [--debug-port <value>] [-n <value>] [--telemetry on|off]
    [--skip-kubernetes-health-check]
FLAGS
  -h, --help                      Show CLI help.
  -n, --chenamespace=<value>      Eclipse Che Kubernetes namespace.
  --debug-port=<value>            [default: 8000] Eclipse Che server debug port
  --skip-kubernetes-health-check  Skip Kubernetes health check
  --telemetry=<option>            Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
                                  <options: on|off>
DESCRIPTION
  Enable local debug of Eclipse Che server
See code: src/commands/server/debug.ts
delete any Eclipse Che related resource
USAGE
  $ chectl server:delete [-h] [-n <value>] [--delete-all] [--delete-namespace] [--telemetry on|off]
    [--skip-kubernetes-health-check] [-y | --batch]
FLAGS
  -h, --help                      Show CLI help.
  -n, --chenamespace=<value>      Eclipse Che Kubernetes namespace.
  -y, --yes                       Automatic yes to prompts; assume "yes" as answer to all prompts and run
                                  non-interactively
  --batch                         Batch mode. Running a command without end user interaction.
  --delete-all                    Indicates to delete Eclipse Che and Dev Workspace related resources
  --delete-namespace              Indicates that a Eclipse Che namespace will be deleted as well
  --skip-kubernetes-health-check  Skip Kubernetes health check
  --telemetry=<option>            Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
                                  <options: on|off>
DESCRIPTION
  delete any Eclipse Che related resource
See code: src/commands/server/delete.ts
Deploy Eclipse Che server
USAGE
  $ chectl server:deploy [-h] [-n <value>] [--batch] [-i <value>] [-t <value>] [--devfile-registry-url <value>]
    [--plugin-registry-url <value>] [--k8spodwaittimeout <value>] [--k8spodreadytimeout <value>]
    [--k8spoddownloadimagetimeout <value>] [--k8spoderrorrechecktimeout <value>] [-d <value>] [-p
    minikube|k8s|openshift|microk8s|docker-desktop|crc] [-b <value>] [--debug] [--che-operator-image <value>]
    [--che-operator-cr-yaml <value>] [--che-operator-cr-patch-yaml <value>] [--workspace-pvc-storage-class-name <value>]
    [--skip-version-check] [--skip-cert-manager] [--skip-devworkspace-operator] [--auto-update] [--starting-csv <value>]
    [--package-manifest-name <value>] [--catalog-source-yaml <value> --olm-channel <value>] [--catalog-source-name
    <value> --catalog-source-namespace <value> ] [--catalog-source-image <value> ] [--cluster-monitoring] [--telemetry
    on|off] [--skip-kubernetes-health-check]
FLAGS
  -b, --domain=<value>
      Domain of the Kubernetes cluster (e.g. example.k8s-cluster.com or <local-ip>.nip.io)
      This flag makes sense only for Kubernetes family infrastructures and will be autodetected for Minikube and MicroK8s
      in most cases.
      However, for Kubernetes cluster it is required to specify.
      Please note, that just setting this flag will not likely work out of the box.
      According changes should be done in Kubernetes cluster configuration as well.
      In case of Openshift, domain adjustment should be done on the cluster configuration level.
  -d, --directory=<value>
      Directory to store logs into
  -h, --help
      Show CLI help.
  -i, --cheimage=<value>
      Eclipse Che server container image
  -n, --chenamespace=<value>
      Eclipse Che Kubernetes namespace.
  -p, --platform=<option>
      Type of Kubernetes platform.
      <options: minikube|k8s|openshift|microk8s|docker-desktop|crc>
  -t, --templates=<value>
      Path to the templates folder
  --[no-]auto-update
      Auto update approval strategy for installation Eclipse Che.
      With this strategy will be provided auto-update Eclipse Che without any human interaction.
      By default this flag is enabled.
  --batch
      Batch mode. Running a command without end user interaction.
  --catalog-source-image=<value>
      OLM catalog source image or index bundle (IIB) from which to install the Eclipse Che operator.
  --catalog-source-name=<value>
      Name of the OLM catalog source or index bundle (IIB) from which to install Eclipse Che operator.
  --catalog-source-namespace=<value>
      Namespace for OLM catalog source to install Eclipse Che operator.
  --catalog-source-yaml=<value>
      Path to a yaml file that describes custom catalog source for installation Eclipse Che operator.
      Catalog source will be applied to the namespace with Eclipse Che operator.
      Also you need define 'olm-channel' name and 'package-manifest-name'.
  --che-operator-cr-patch-yaml=<value>
      Path to a yaml file that overrides the default values in CheCluster CR used by the operator. This parameter is used
      only when the installer is the 'operator' or the 'olm'.
  --che-operator-cr-yaml=<value>
      Path to a yaml file that defines a CheCluster used by the operator.
  --che-operator-image=<value>
      Container image of the operator.
  --cluster-monitoring
      Enable cluster monitoring to scrape Eclipse Che metrics in Prometheus.
      This parameter is used only when the platform is 'openshift'.
  --debug
      'Enables the debug mode for Eclipse Che server. To debug Eclipse Che server from localhost use 'server:debug'
      command.'
  --devfile-registry-url=<value>
      The URL of the external Devfile registry.
  --k8spoddownloadimagetimeout=<value>
      [default: 1200000] Waiting time for Pod downloading image (in milliseconds)
  --k8spoderrorrechecktimeout=<value>
      [default: 60000] Waiting time for Pod rechecking error (in milliseconds)
  --k8spodreadytimeout=<value>
      [default: 120000] Waiting time for Pod Ready condition (in milliseconds)
  --k8spodwaittimeout=<value>
      [default: 120000] Waiting time for Pod scheduled condition (in milliseconds)
  --olm-channel=<value>
      Olm channel to install Eclipse Che, f.e. stable.
      If options was not set, will be used default version for package manifest.
  --package-manifest-name=<value>
      Package manifest name to subscribe to Eclipse Che OLM package manifest.
  --plugin-registry-url=<value>
      The URL of the external plugin registry.
  --skip-cert-manager
      Skip installing Cert Manager (Kubernetes cluster only).
  --skip-devworkspace-operator
      Skip installing Dev Workspace Operator.
  --skip-kubernetes-health-check
      Skip Kubernetes health check
  --skip-version-check
      Skip minimal versions check.
  --starting-csv=<value>
      Starting cluster service version(CSV) for installation Eclipse Che.
      Flags uses to set up start installation version Che.
      For example: 'starting-csv' provided with value 'eclipse-che.v7.10.0' for stable channel.
      Then OLM will install Eclipse Che with version 7.10.0.
      Notice: this flag will be ignored with 'auto-update' flag. OLM with auto-update mode installs the latest known
      version.
  --telemetry=<option>
      Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
      <options: on|off>
  --workspace-pvc-storage-class-name=<value>
      persistent volume(s) storage class name to use to store Eclipse Che workspaces data
DESCRIPTION
  Deploy Eclipse Che server
See code: src/commands/server/deploy.ts
Collect Eclipse Che logs
USAGE
  $ chectl server:logs [-h] [-d <value>] [-n <value>] [--telemetry on|off] [--skip-kubernetes-health-check]
FLAGS
  -d, --directory=<value>         Directory to store logs into
  -h, --help                      Show CLI help.
  -n, --chenamespace=<value>      Eclipse Che Kubernetes namespace.
  --skip-kubernetes-health-check  Skip Kubernetes health check
  --telemetry=<option>            Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
                                  <options: on|off>
DESCRIPTION
  Collect Eclipse Che logs
See code: src/commands/server/logs.ts
Start Eclipse Che server
USAGE
  $ chectl server:start [-h] [-n <value>] [--telemetry on|off] [--skip-kubernetes-health-check] [--batch]
    [--k8spodwaittimeout <value>] [--k8spodreadytimeout <value>] [--k8spoddownloadimagetimeout <value>]
    [--k8spoderrorrechecktimeout <value>] [-d <value>]
FLAGS
  -d, --directory=<value>               Directory to store logs into
  -h, --help                            Show CLI help.
  -n, --chenamespace=<value>            Eclipse Che Kubernetes namespace.
  --batch                               Batch mode. Running a command without end user interaction.
  --k8spoddownloadimagetimeout=<value>  [default: 1200000] Waiting time for Pod downloading image (in milliseconds)
  --k8spoderrorrechecktimeout=<value>   [default: 60000] Waiting time for Pod rechecking error (in milliseconds)
  --k8spodreadytimeout=<value>          [default: 120000] Waiting time for Pod Ready condition (in milliseconds)
  --k8spodwaittimeout=<value>           [default: 120000] Waiting time for Pod scheduled condition (in milliseconds)
  --skip-kubernetes-health-check        Skip Kubernetes health check
  --telemetry=<option>                  Enable or disable telemetry. This flag skips a prompt and enable/disable
                                        telemetry
                                        <options: on|off>
DESCRIPTION
  Start Eclipse Che server
See code: src/commands/server/start.ts
Status Eclipse Che server
USAGE
  $ chectl server:status [-h] [-n <value>] [--telemetry on|off]
FLAGS
  -h, --help                  Show CLI help.
  -n, --chenamespace=<value>  Eclipse Che Kubernetes namespace.
  --telemetry=<option>        Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
                              <options: on|off>
DESCRIPTION
  Status Eclipse Che server
See code: src/commands/server/status.ts
stop Eclipse Che server
USAGE
  $ chectl server:stop [-h] [-n <value>] [--telemetry on|off] [--skip-kubernetes-health-check]
FLAGS
  -h, --help                      Show CLI help.
  -n, --chenamespace=<value>      Eclipse Che Kubernetes namespace.
  --skip-kubernetes-health-check  Skip Kubernetes health check
  --telemetry=<option>            Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
                                  <options: on|off>
DESCRIPTION
  stop Eclipse Che server
See code: src/commands/server/stop.ts
Update Eclipse Che server.
USAGE
  $ chectl server:update [-h] [-n <value>] [-y | --batch] [-t <value>] [--che-operator-image <value>]
    [--che-operator-cr-patch-yaml <value>] [--skip-devworkspace-operator] [--skip-kubernetes-health-check]
    [--skip-version-check] [--telemetry on|off] [--package-manifest-name <value>] [--catalog-source-namespace <value>
    --catalog-source-name <value> --olm-channel <value>] [--catalog-source-yaml <value> ] [--catalog-source-image
    <value> ] [--auto-update] [--starting-csv <value>]
FLAGS
  -h, --help
      Show CLI help.
  -n, --chenamespace=<value>
      Eclipse Che Kubernetes namespace.
  -t, --templates=<value>
      Path to the templates folder
  -y, --yes
      Automatic yes to prompts; assume "yes" as answer to all prompts and run non-interactively
  --[no-]auto-update
      Auto update approval strategy for installation Eclipse Che.
      With this strategy will be provided auto-update Eclipse Che without any human interaction.
      By default this flag is enabled.
  --batch
      Batch mode. Running a command without end user interaction.
  --catalog-source-image=<value>
      OLM catalog source image or index bundle (IIB) from which to install the Eclipse Che operator.
  --catalog-source-name=<value>
      Name of the OLM catalog source or index bundle (IIB) from which to install Eclipse Che operator.
  --catalog-source-namespace=<value>
      Namespace for OLM catalog source to install Eclipse Che operator.
  --catalog-source-yaml=<value>
      Path to a yaml file that describes custom catalog source for installation Eclipse Che operator.
      Catalog source will be applied to the namespace with Eclipse Che operator.
      Also you need define 'olm-channel' name and 'package-manifest-name'.
  --che-operator-cr-patch-yaml=<value>
      Path to a yaml file that overrides the default values in CheCluster CR used by the operator. This parameter is used
      only when the installer is the 'operator' or the 'olm'.
  --che-operator-image=<value>
      Container image of the operator.
  --olm-channel=<value>
      Olm channel to install Eclipse Che, f.e. stable.
      If options was not set, will be used default version for package manifest.
  --package-manifest-name=<value>
      Package manifest name to subscribe to Eclipse Che OLM package manifest.
  --skip-devworkspace-operator
      Skip installing Dev Workspace Operator.
  --skip-kubernetes-health-check
      Skip Kubernetes health check
  --skip-version-check
      Skip minimal versions check.
  --starting-csv=<value>
      Starting cluster service version(CSV) for installation Eclipse Che.
      Flags uses to set up start installation version Che.
      For example: 'starting-csv' provided with value 'eclipse-che.v7.10.0' for stable channel.
      Then OLM will install Eclipse Che with version 7.10.0.
      Notice: this flag will be ignored with 'auto-update' flag. OLM with auto-update mode installs the latest known
      version.
  --telemetry=<option>
      Enable or disable telemetry. This flag skips a prompt and enable/disable telemetry
      <options: on|off>
DESCRIPTION
  Update Eclipse Che server.
EXAMPLES
  # Update Eclipse Che:
    $ chectl server:update
  # Update Eclipse Che in 'eclipse-che' namespace:
    $ chectl server:update -n eclipse-che
  # Update Eclipse Che and update its configuration in the custom resource:
    $ chectl server:update --che-operator-cr-patch-yaml patch.yaml
  # Update Eclipse Che from the provided channel:
    $ chectl server:update --olm-channel next
  # Update Eclipse Che from the provided CatalogSource and channel:
    $ chectl server:update --olm-channel fast --catalog-source-name MyCatalogName --catalog-source-namespace \
      MyCatalogNamespace
  # Create CatalogSource based on provided image and update Eclipse Che from it:
    $ chectl server:update --olm-channel latest --catalog-source-image MyCatalogImage
  # Create a CatalogSource defined in yaml file and update Eclipse Che from it:
    $ chectl server:update --olm-channel stable --catalog-source-yaml PATH_TO_CATALOG_SOURCE_YAML
See code: src/commands/server/update.ts
update the chectl CLI
USAGE
  $ chectl update [CHANNEL] [--from-local]
FLAGS
  --from-local  interactively choose an already installed version
DESCRIPTION
  update the chectl CLI
See code: @oclif/plugin-update
USAGE
  $ chectl version [--json] [--verbose]
FLAGS
  --verbose  Show additional information about the CLI.
GLOBAL FLAGS
  --json  Format output as json.
FLAG DESCRIPTIONS
  --verbose  Show additional information about the CLI.
    Additionally shows the architecture, node version, operating system, and versions of plugins that the CLI is using.
See code: @oclif/plugin-version
Contributing to chectl is covered in CONTRIBUTING.md
This repo contains several actions, including:
Downstream builds can be found at the link below, which is internal to Red Hat. Stable builds can be found by replacing the 3.x with a specific version like 3.2.
See also:
Eclipse Che® is open sourced under the Eclipse Public License 2.0.
"Che" is a trademark of the Eclipse Foundation.