docs/user-guide/plugins.md
This guide demonstrates how to write plugins for the
argocd CLI tool. Plugins are a way to extend argocd CLI with new sub-commands,
allowing for custom features which are not part of the default distribution
of the argocd CLI.
If you would like to take a look at the original proposal, head over to this enhancement proposal. It covers how the plugin mechanism works, its benefits, motivations, and the goals it aims to achieve.
You need to have a working argocd binary installed locally. You can follow
the cli installation documentation to install the binary.
argocd pluginsA plugin is a standalone executable file whose name begins with argocd-.
To install a plugin, move its executable file to any directory included in your PATH.
Ensure that the PATH configuration specifies the full absolute path to the executable,
not a relative path. argocd allows plugins to add custom commands such as
argocd my-plugin arg1 arg2 --flag1 by executing a argocd-my-plugin binary in the PATH.
It is currently not possible to create plugins that overwrite existing
argocd commands. For example, creating a plugin such as argocd-version
will cause the plugin to never get executed, as the existing argocd version
command will always take precedence over it. Due to this limitation, it is
also not possible to use plugins to add new subcommands to existing argocd commands.
For example, adding a subcommand argocd cluster upgrade by naming your plugin
argocd-cluster will cause the plugin to be ignored.
It is currently not possible to parse the global flags set by argocd CLI. For example,
if you have set any global flag value such as --logformat value to text, the plugin will
not parse the global flags and pass the default value to the --logformat flag which is json.
The flag parsing will work exactly the same way for existing argocd commands which means executing a
existing argocd command such as argocd cluster list will correctly parse the flag value as text.
argocd pluginAny binary that you would want to execute as an argocd plugin need to satisfy the following three conditions:
argocd- as the prefix name. For example,
argocd-demo-plugin or argocd-demo_plugin is a valid binary name but not
argocd_demo-plugin or argocd_demo_plugin.argocd pluginsAn Argo CD plugin’s filename must start with argocd-. The subcommands implemented
by the plugin are determined by the portion of the filename after the argocd- prefix.
Anything after argocd- will become a subcommand for argocd.
For example, A plugin named argocd-demo-plugin is invoked when the user types:
argocd demo-plugin [args] [flags]
The argocd CLI determines which plugin to invoke based on the subcommands provided.
For example, executing the following command:
argocd my-custom-command [args] [flags]
will lead to the execution of plugin named argocd-my-custom-command if it is present in the PATH.
A plugin can be written in any programming language or script that allows you to write command-line commands.
A plugin determines which command path it wishes to implement based on its name.
For example, If a binary named argocd-demo-plugin is available in your system's absolute PATH, and the user runs the following command:
argocd demo-plugin subcommand1 --flag=true
Argo CD will translate and execute the corresponding plugin with the following command:
argocd-demo-plugin subcommand1 --flag=true
Similarly, if a plugin named argocd-demo-demo-plugin is found in the absolute PATH, and the user invokes:
argocd demo-demo-plugin subcommand2 subcommand3 --flag=true
Argo CD will execute the plugin as:
argocd-demo-demo-plugin subcommand2 subcommand3 --flag=true
#!/bin/bash
# Check if the argocd CLI is installed
if ! command -v argocd &> /dev/null; then
echo "Error: Argo CD CLI (argocd) is not installed. Please install it first."
exit 1
fi
if [[ "$1" == "version" ]]
then
echo "displaying argocd version..."
argocd version
exit 0
fi
echo "I am a plugin named argocd-foo"
To use a plugin, make the plugin executable:
sudo chmod +x ./argocd-foo
and place it anywhere in your PATH:
sudo mv ./argocd-foo /usr/local/bin
You may now invoke your plugin as a argocd command:
argocd foo
This would give the following output
I am a plugin named argocd-foo
All args and flags are passed as-is to the executable:
argocd foo version
This would give the following output
DEBU[0000] command does not exist, looking for a plugin...
displaying argocd version...
2025/01/16 13:24:36 maxprocs: Leaving GOMAXPROCS=16: CPU quota undefined
argocd: v2.13.0-rc2+0f083c9
BuildDate: 2024-09-20T11:59:25Z
GitCommit: 0f083c9e58638fc292cf064e294a1aa53caa5630
GitTreeState: clean
GoVersion: go1.22.7
Compiler: gc
Platform: linux/amd64
argocd-server: v2.13.0-rc2+0f083c9
BuildDate: 2024-09-20T11:59:25Z
GitCommit: 0f083c9e58638fc292cf064e294a1aa53caa5630
GitTreeState: clean
GoVersion: go1.22.7
Compiler: gc
Platform: linux/amd64
Kustomize Version: v5.4.3 2024-07-19T16:40:33Z
Helm Version: v3.15.2+g1a500d5
Kubectl Version: v0.31.0
Jsonnet Version: v0.20.0
argocd pluginsIf you’ve developed an Argo CD plugin for others to use, you should carefully consider how to package, distribute, and deliver updates to ensure a smooth installation and upgrade process for your users.
You can distribute your plugin using traditional package managers,
such as apt or yum for Linux, Chocolatey for Windows, and Homebrew for macOS.
These package managers are well-suited for distributing plugins as they can
place executables directly into the user's PATH, making them easily accessible.
However, as a plugin author, choosing this approach comes with the responsibility of maintaining and updating the plugin's distribution packages across multiple platforms for every release. This includes testing for compatibility, ensuring timely updates, and managing versioning to provide a seamless experience for your users.
You can publish the source code of your plugin, for example, in a Git repository. This allows users to access and inspect the code directly. Users who want to install the plugin will need to fetch the code, set up a suitable build environment (if the plugin requires compiling), and manually deploy it.