-
Notifications
You must be signed in to change notification settings - Fork 49
/
Copy pathuse-cli-plugins.html.md.erb
167 lines (97 loc) · 5.76 KB
/
use-cli-plugins.html.md.erb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
---
title: Using a cf CLI plug-in
owner: CLI
---
The Cloud Foundry CLI (cf CLI) includes plug-in capability. Plug-ins allow you to add custom commands to the cf CLI.
You can install and use the plug-in that Cloud Foundry developers and third-party developers create. For a current list of community-supported plug-ins, see the [Cloud Foundry Community CLI Plug-in page](https://plugins.cloudfoundry.org). For information about submitting your own plug-in, see the [Cloud Foundry CLI Plugin Repository (CLIPR)](https://github.com/cloudfoundry-incubator/cli-plugin-repo) repository on GitHub.
<p class="note important">
Plug-ins are not vetted for security or function. Use plug-ins at your own risk.</p>
The cf CLI identifies a plug-in by binary filename, its developer defined plug-in name, and the commands that the plug-in provides. Use the binary filename only to install a plug-in. You use the plug-in name or a command for any other action.
The cf CLI uses case-sensitive commands, but plug-in management commands accept plug-in and repository names
irrespective of their casing.
## <a id="plugin-directory"></a> Changing the plug-in directory
By default, the cf CLI stores plug-ins on your workstation in `$CF_HOME/.cf/plugins`, which defaults to `$HOME/.cf/plugins`.
To change the root directory of this path from `$CF_HOME`, you must set the `CF_PLUGIN_HOME` environment variable.
The cf CLI appends `.cf/plugins` to the `CF_PLUGIN_HOME` path that you specify and stores plug ins in that location. For example, if you set `CF_PLUGIN_HOME` to `/my-folder`, cf CLI stores plug-ins in `/my-folder/.cf/plugins`.
## <a id="plugin-install"></a> Installing a plug-in
To install a plug-in:
1. Download a binary or the source code for a plug-in from a trusted provider.
The cf CLI requires a binary file compiled from source code written in Go. If you download source code, you must compile the code to create a binary.
2. Run:
```
cf install-plugin BINARY-FILENAME
```
Where `BINARY-FILENAME` is the path to and name of your binary file.
You cannot install a plug in that has the same name or that uses the same command as an existing plugin. If you attempt to do so, you are prompted to uninstall the existing plugin.
The cf CLI prohibits you from implementing any plug-in that uses a native cf CLI command name or alias. For example, if you attempt to install a third-party plugin that includes the <code>cf push</code> command, the cf CLI halts the installation.
For more information, use `cf install-plugin --help`.
## <a id="plugin-run-cmd"></a> Managing plug-ins and running plug-in commands
Use the contents of the `cf help` **CLI plug-in management** and **Commands offered by installed plug-ins** sections to manage plug-ins and run plug-in commands.
To manage plug-ins and run plug-in commands:
1. List all installed plug-ins and all commands that the plug-ins provide by running:
```
cf plugins
```
1. Run a plug-in command:
```
cf PLUGIN-COMMAND
```
Where `PLUGIN-COMMAND` is the plug-in command that you want to run.
## <a id="plugins-outdated"></a> Checking for plug-in updates
To check all registered plug-in repositories for newer versions of currently installed plug-ins:
1. Run:
```
cf plugins --outdated
```
1. See the output of the previous command, in this example:
<pre class="terminal">
$ cf plugins --outdated
Searching CF-Community, company-repo for newer versions of installed plugins...
plugin version latest version
coffeemaker 1.1.2 1.2.0
Use 'cf install-plugin' to update a plugin to the latest version.
</pre>
For more information about the `cf plugins` command, use `cf plugins --help`.
## <a id="plugin-uninstall"></a> Uninstalling a plug-in
To uninstall a plug-in:
1. To view the names of all installed plug-ins, run:
```
cf plugins
```
1. Run:
```
cf uninstall-plugin PLUGIN-NAME
```
Where `PLUGIN-NAME` is the name of the plug-in you want to uninstall.
You must use the name of the plug-in, not the binary filename, to uninstall it.
For more information, use `cf uninstall-plugin --help`.
## <a id="adding-plugin-repo"></a> Adding a plug-in repository
To add a plug-in repository:
1. Run:
```
cf add-plugin-repo REPOSITORY-NAME-URL
```
Where `REPOSITORY-NAME-URL` is the URL of the plug-in repository that you want to add.
For more information, use `cf add-plugin-repo --help`.
## <a id="listing-plugin-repo"></a> Viewing available plug-in repositories
To view your available plug-in repositories:
1. Run:
```
cf list-plugin-repos
```
For more information, use `cf list-plugin-repos --help`.
## <a id="listing-plugin-repo"></a> Listing all plug-ins by repository
To show all plug-ins from all available repositories:
1. Run:
```
cf repo-plugins
```
For more information, use `cf repo-plugins --help`.
## <a id="troubleshoot"></a> Troubleshooting
The cf CLI provides the following error messages to help you troubleshoot installation and usage issues. Third-party plug-ins provide their own error messages.
### <a id='permission-denied'></a> Permission denied
If you receive a `permission denied` error message, you lack required permissions to the plug-in. You must have `read` and `execute` permissions to the plug-in binary file.
### <a id='plugin-command-collision'></a> Plug-in command collision
Plug-in names and commands must be unique. The CLI displays an error message if you attempt to install a plug-in with a non unique name or command.
If the plug-in has the same name or command as a currently installed plug-in, you must uninstall the existing plug-in to install the new plug-in.
If the plug-in has a command with the same name as a native cf CLI command or alias, you cannot install the plug-in.