-
Notifications
You must be signed in to change notification settings - Fork 1.5k
/
Copy pathplugin.go
86 lines (73 loc) · 2.86 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
/*
Copyright 2020 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package plugin
import (
"sigs.k8s.io/kubebuilder/v4/pkg/config"
)
// Plugin is an interface that defines the common base for all plugins.
type Plugin interface {
// Name returns a DNS1123 label string identifying the plugin uniquely. This name should be fully-qualified,
// i.e. have a short prefix describing the plugin type (like a language) followed by a domain.
// For example, Kubebuilder's main plugin would return "go.kubebuilder.io".
Name() string
// Version returns the plugin's version.
//
// NOTE: this version is different from config version.
Version() Version
// SupportedProjectVersions lists all project configuration versions this plugin supports.
// The returned slice cannot be empty.
SupportedProjectVersions() []config.Version
}
// Deprecated is an interface that defines the messages for plugins that are deprecated.
type Deprecated interface {
// DeprecationWarning returns a string indicating a plugin is deprecated.
DeprecationWarning() string
}
// Init is an interface for plugins that provide an `init` subcommand.
type Init interface {
Plugin
// GetInitSubcommand returns the underlying InitSubcommand interface.
GetInitSubcommand() InitSubcommand
}
// CreateAPI is an interface for plugins that provide a `create api` subcommand.
type CreateAPI interface {
Plugin
// GetCreateAPISubcommand returns the underlying CreateAPISubcommand interface.
GetCreateAPISubcommand() CreateAPISubcommand
}
// CreateWebhook is an interface for plugins that provide a `create webhook` subcommand.
type CreateWebhook interface {
Plugin
// GetCreateWebhookSubcommand returns the underlying CreateWebhookSubcommand interface.
GetCreateWebhookSubcommand() CreateWebhookSubcommand
}
// Edit is an interface for plugins that provide a `edit` subcommand.
type Edit interface {
Plugin
// GetEditSubcommand returns the underlying EditSubcommand interface.
GetEditSubcommand() EditSubcommand
}
// Full is an interface for plugins that provide `init`, `create api`, `create webhook` and `edit` subcommands.
type Full interface {
Init
CreateAPI
CreateWebhook
Edit
}
// Bundle allows to group plugins under a single key.
type Bundle interface {
Plugin
// Plugins returns a list of the bundled plugins.
// The returned list should be flattened, i.e., no plugin bundles should be part of this list.
Plugins() []Plugin
}