Skip to content

Commit

Permalink
sparkles: (go/v3-alpha) Add the --force option for the webhook
Browse files Browse the repository at this point in the history
  • Loading branch information
prafull01 committed Dec 15, 2020
1 parent 762211a commit e604838
Show file tree
Hide file tree
Showing 11 changed files with 66 additions and 11 deletions.
3 changes: 3 additions & 0 deletions generate_testdata.sh
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,9 @@ scaffold_test_project() {
$kb create api --group crew --version v1 --kind Admiral --controller=true --resource=true --namespaced=false --make=false
$kb create webhook --group crew --version v1 --kind Admiral --defaulting
$kb create api --group crew --version v1 --kind Laker --controller=true --resource=false --make=false
if [ $project == "project-v3" ]; then
$kb create webhook --group crew --version v1 --kind Captain --defaulting --programmatic-validation --force
fi
elif [[ $project =~ multigroup ]]; then
header_text 'Switching to multigroup layout ...'
$kb edit --multigroup=true
Expand Down
2 changes: 1 addition & 1 deletion pkg/cli/cli.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ type CLI interface {

// cli defines the command line structure and interfaces that are used to
// scaffold kubebuilder project files.
type cli struct {
type cli struct { //nolint:maligned
/* Fields set by Option */

// Root command name. It is injected downstream to provide correct help, usage, examples and errors.
Expand Down
3 changes: 1 addition & 2 deletions pkg/cli/edit.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and
limitations under the License.
*/

package cli
package cli // nolint:dupl

import (
"fmt"
Expand Down Expand Up @@ -50,7 +50,6 @@ func (c cli) newEditContext() plugin.Context {
}
}

// nolint:dupl
func (c cli) bindEdit(ctx plugin.Context, cmd *cobra.Command) {
if len(c.resolvedPlugins) == 0 {
cmdErr(cmd, fmt.Errorf(noPluginError))
Expand Down
11 changes: 11 additions & 0 deletions pkg/model/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,17 @@ func (c Config) HasGroup(group string) bool {
return false
}

// HasWebhook returns true if webhook is already present
func (c Config) HasWebhook(resource ResourceData) bool {
for _, r := range c.Resources {
if r.isGVKEqualTo(resource) {
return r.Webhooks != nil
}
}

return false
}

// IsCRDVersionCompatible returns true if crdVersion can be added to the existing set of CRD versions.
func (c Config) IsCRDVersionCompatible(crdVersion string) bool {
return c.resourceAPIVersionCompatible("crd", crdVersion)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ type Webhook struct { // nolint:maligned
Defaulting bool
// If scaffold the validating webhook
Validating bool

Force bool
}

// SetTemplateDefaults implements file.Template
Expand Down Expand Up @@ -69,7 +71,11 @@ func (f *Webhook) SetTemplateDefaults() error {
}
f.TemplateBody = webhookTemplate

f.IfExistsAction = file.Error
if f.Force {
f.IfExistsAction = file.Overwrite
} else {
f.IfExistsAction = file.Error
}

f.GroupDomainWithDash = strings.Replace(f.Resource.Domain, ".", "-", -1)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,8 @@ var _ file.Template = &ManagerWebhookPatch{}
// ManagerWebhookPatch scaffolds a file that defines the patch that enables webhooks on the manager
type ManagerWebhookPatch struct {
file.TemplateMixin

Force bool
}

// SetTemplateDefaults implements file.Template
Expand All @@ -37,8 +39,12 @@ func (f *ManagerWebhookPatch) SetTemplateDefaults() error {

f.TemplateBody = managerWebhookPatchTemplate

// If file exists (ex. because a webhook was already created), skip creation.
f.IfExistsAction = file.Skip
if f.Force {
f.IfExistsAction = file.Overwrite
} else {
// If file exists (ex. because a webhook was already created), skip creation.
f.IfExistsAction = file.Skip
}

return nil
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ type Kustomization struct {

// Version of webhook the project was configured with.
WebhookVersion string

Force bool
}

// SetTemplateDefaults implements file.Template
Expand All @@ -40,8 +42,12 @@ func (f *Kustomization) SetTemplateDefaults() error {

f.TemplateBody = kustomizeWebhookTemplate

// If file exists (ex. because a webhook was already created), skip creation.
f.IfExistsAction = file.Skip
if f.Force {
f.IfExistsAction = file.Overwrite
} else {
// If file exists (ex. because a webhook was already created), skip creation.
f.IfExistsAction = file.Skip
}

if f.WebhookVersion == "" {
f.WebhookVersion = "v1"
Expand Down
7 changes: 5 additions & 2 deletions pkg/plugins/golang/v3/scaffolds/webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ type webhookScaffolder struct {
resource *resource.Resource

// Webhook type options.
defaulting, validation, conversion bool
defaulting, validation, conversion, force bool
}

// NewWebhookScaffolder returns a new Scaffolder for v2 webhook creation operations
Expand All @@ -49,6 +49,7 @@ func NewWebhookScaffolder(
defaulting bool,
validation bool,
conversion bool,
force bool,
) cmdutil.Scaffolder {
return &webhookScaffolder{
config: config,
Expand All @@ -57,6 +58,7 @@ func NewWebhookScaffolder(
defaulting: defaulting,
validation: validation,
conversion: conversion,
force: force,
}
}

Expand Down Expand Up @@ -88,11 +90,12 @@ You need to implement the conversion.Hub and conversion.Convertible interfaces f
WebhookVersion: s.resource.Webhooks.WebhookVersion,
Defaulting: s.defaulting,
Validating: s.validation,
Force: s.force,
},
&templates.MainUpdater{WireWebhook: true},
&kdefault.WebhookCAInjectionPatch{WebhookVersion: s.resource.Webhooks.WebhookVersion},
&kdefault.ManagerWebhookPatch{},
&webhook.Kustomization{WebhookVersion: s.resource.Webhooks.WebhookVersion},
&webhook.Kustomization{WebhookVersion: s.resource.Webhooks.WebhookVersion, Force: s.force},
&webhook.KustomizeConfig{},
&webhook.Service{},
); err != nil {
Expand Down
13 changes: 12 additions & 1 deletion pkg/plugins/golang/v3/webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ limitations under the License.
package v3

import (
"errors"
"fmt"
"io/ioutil"
"path/filepath"
Expand Down Expand Up @@ -44,6 +45,9 @@ type createWebhookSubcommand struct {
validation bool
conversion bool

// force indicates that the resource should be created even if it already exists
force bool

// runMake indicates whether to run make or not after scaffolding webhooks
runMake bool
}
Expand Down Expand Up @@ -79,6 +83,8 @@ func (p *createWebhookSubcommand) BindFlags(fs *pflag.FlagSet) {
"version of {Mutating,Validating}WebhookConfigurations to scaffold. Options: [v1, v1beta1]")

fs.BoolVar(&p.runMake, "make", true, "if true, run make after generating files")
fs.BoolVar(&p.force, "force", false,
"attempt to create resource even if it already exists")

fs.BoolVar(&p.defaulting, "defaulting", false,
"if set, scaffold the defaulting webhook")
Expand Down Expand Up @@ -112,6 +118,10 @@ func (p *createWebhookSubcommand) Validate() error {
" kind and version provided", p.commandName)
}

if p.config.HasWebhook(p.resource.Data()) && !p.force {
return errors.New("webhook resource already exists")
}

if !p.config.IsWebhookVersionCompatible(p.resource.Webhooks.WebhookVersion) {
return fmt.Errorf("only one webhook version can be used for all resources, cannot add %q",
p.resource.Webhooks.WebhookVersion)
Expand All @@ -129,7 +139,8 @@ func (p *createWebhookSubcommand) GetScaffolder() (cmdutil.Scaffolder, error) {

// Create the actual resource from the resource options
res := p.resource.NewResource(p.config, false)
return scaffolds.NewWebhookScaffolder(p.config, string(bp), res, p.defaulting, p.validation, p.conversion), nil
return scaffolds.NewWebhookScaffolder(p.config, string(bp), res, p.defaulting, p.validation, p.conversion,
p.force), nil
}

func (p *createWebhookSubcommand) PostScaffold() error {
Expand Down
6 changes: 6 additions & 0 deletions testdata/project-v3/api/v1/webhook_suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,9 @@ var _ = BeforeSuite(func() {
err = admissionv1beta1.AddToScheme(scheme)
Expect(err).NotTo(HaveOccurred())

err = admissionv1beta1.AddToScheme(scheme)
Expect(err).NotTo(HaveOccurred())

// +kubebuilder:scaffold:scheme

k8sClient, err = client.New(cfg, client.Options{Scheme: scheme})
Expand All @@ -108,6 +111,9 @@ var _ = BeforeSuite(func() {
err = (&Admiral{}).SetupWebhookWithManager(mgr)
Expect(err).NotTo(HaveOccurred())

err = (&Captain{}).SetupWebhookWithManager(mgr)
Expect(err).NotTo(HaveOccurred())

// +kubebuilder:scaffold:webhook

go func() {
Expand Down
4 changes: 4 additions & 0 deletions testdata/project-v3/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,10 @@ func main() {
setupLog.Error(err, "unable to create controller", "controller", "Laker")
os.Exit(1)
}
if err = (&crewv1.Captain{}).SetupWebhookWithManager(mgr); err != nil {
setupLog.Error(err, "unable to create webhook", "webhook", "Captain")
os.Exit(1)
}
// +kubebuilder:scaffold:builder

if err := mgr.AddHealthzCheck("health", healthz.Ping); err != nil {
Expand Down

0 comments on commit e604838

Please sign in to comment.