-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathplugin.go
255 lines (207 loc) · 4.95 KB
/
plugin.go
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
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
// Code generated by lesiw.io/ctrctl. DO NOT EDIT.
package ctrctl
import (
"fmt"
"os/exec"
)
type PluginCreateOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Compress the context using gzip.
Compress bool
// Print usage.
Help bool
}
// Create a plugin from a rootfs and configuration. Plugin data directory must contain config.json and rootfs directory.
func PluginCreate(opts *PluginCreateOpts, plugin string, pluginDataDir string) (string, error) {
return runCtrCmd(
[]string{"plugin", "create"},
[]string{plugin, pluginDataDir},
opts,
0,
)
}
type PluginDisableOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Force the disable of an active plugin.
Force bool
// Print usage.
Help bool
}
// Disable a plugin.
func PluginDisable(opts *PluginDisableOpts, plugin string) (string, error) {
return runCtrCmd(
[]string{"plugin", "disable"},
[]string{plugin},
opts,
0,
)
}
type PluginEnableOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Print usage.
Help bool
// HTTP client timeout (in seconds).
Timeout *int
}
// Enable a plugin.
func PluginEnable(opts *PluginEnableOpts, plugin string) (string, error) {
return runCtrCmd(
[]string{"plugin", "enable"},
[]string{plugin},
opts,
0,
)
}
type PluginInspectOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Format output using a custom template:
// 'json': Print in JSON format.
// 'TEMPLATE': Print output using the given Go template.
// Refer to https://docs.docker.com/go/formatting/ for more information about formatting output with templates.
Format string
// Print usage.
Help bool
}
// Display detailed information on one or more plugins.
func PluginInspect(opts *PluginInspectOpts, plugin ...string) (string, error) {
if len(plugin) == 0 {
return "", fmt.Errorf("plugin must have at least one value")
}
return runCtrCmd(
[]string{"plugin", "inspect"},
plugin,
opts,
0,
)
}
type PluginInstallOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Local name for plugin.
Alias string
// Do not enable the plugin on install.
Disable bool
// Skip image verification.
DisableContentTrust bool
// Grant all permissions necessary to run the plugin.
GrantAllPermissions bool
// Print usage.
Help bool
}
// Install a plugin.
func PluginInstall(opts *PluginInstallOpts, plugin string, keyValue ...string) (string, error) {
return runCtrCmd(
[]string{"plugin", "install"},
append([]string{plugin}, keyValue...),
opts,
0,
)
}
type PluginLsOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Provide filter values (e.g. `enabled=true`).
Filter string
// Format output using a custom template:
// 'table': Print output in table format with column headers (default).
// 'table TEMPLATE': Print output in table format using the given Go template.
// 'json': Print in JSON format.
// 'TEMPLATE': Print output using the given Go template.
// Refer to https://docs.docker.com/go/formatting/ for more information about formatting output with templates.
Format string
// Print usage.
Help bool
// Don't truncate output.
NoTrunc bool
// Only display plugin IDs.
Quiet bool
}
// List plugins.
func PluginLs(opts *PluginLsOpts) (string, error) {
return runCtrCmd(
[]string{"plugin", "ls"},
[]string{},
opts,
0,
)
}
type PluginPushOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Skip image signing.
DisableContentTrust bool
// Print usage.
Help bool
}
// Push a plugin to a registry.
func PluginPush(opts *PluginPushOpts, pluginTag string) (string, error) {
return runCtrCmd(
[]string{"plugin", "push"},
[]string{pluginTag},
opts,
0,
)
}
type PluginRmOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Force the removal of an active plugin.
Force bool
// Print usage.
Help bool
}
// Remove one or more plugins.
func PluginRm(opts *PluginRmOpts, plugin ...string) (string, error) {
if len(plugin) == 0 {
return "", fmt.Errorf("plugin must have at least one value")
}
return runCtrCmd(
[]string{"plugin", "rm"},
plugin,
opts,
0,
)
}
type PluginSetOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Print usage.
Help bool
}
// Change settings for a plugin.
func PluginSet(opts *PluginSetOpts, plugin string, keyValue ...string) (string, error) {
if len(keyValue) == 0 {
return "", fmt.Errorf("keyValue must have at least one value")
}
return runCtrCmd(
[]string{"plugin", "set"},
append([]string{plugin}, keyValue...),
opts,
-1,
)
}
type PluginUpgradeOpts struct {
// Base exec.Cmd.
Cmd *exec.Cmd
// Skip image verification.
DisableContentTrust bool
// Grant all permissions necessary to run the plugin.
GrantAllPermissions bool
// Print usage.
Help bool
// Do not check if specified remote plugin matches existing plugin image.
SkipRemoteCheck bool
}
// Upgrade an existing plugin.
func PluginUpgrade(opts *PluginUpgradeOpts, plugin string, remote string) (string, error) {
return runCtrCmd(
[]string{"plugin", "upgrade"},
[]string{plugin, remote},
opts,
0,
)
}