From 94f702e46a86d00db7342abdb715c18abdec2bcd Mon Sep 17 00:00:00 2001 From: Christoph Hartmann Date: Wed, 18 Oct 2023 23:12:19 +0200 Subject: [PATCH] =?UTF-8?q?=E2=AD=90=EF=B8=8F=20install=20provider=20befor?= =?UTF-8?q?e=20lint=20and=20fmt=20(#857)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/cnspec/cmd/bundle.go | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/apps/cnspec/cmd/bundle.go b/apps/cnspec/cmd/bundle.go index 9bf0630d..67145aeb 100644 --- a/apps/cnspec/cmd/bundle.go +++ b/apps/cnspec/cmd/bundle.go @@ -45,6 +45,23 @@ func init() { rootCmd.AddCommand(policyBundlesCmd) } +// ensureProviders ensures that all providers are locally installed +func ensureProviders() error { + providerList := []string{} + + for k := range providers.DefaultProviders { + providerList = append(providerList, k) + } + + // ensure that the providers are loaded + for _, connectionName := range providerList { + if _, err := providers.EnsureProvider(connectionName, "", true, nil); err != nil { + return err + } + } + return nil +} + var policyBundlesCmd = &cobra.Command{ Use: "bundle", Short: "Manage policy bundles.", @@ -87,6 +104,7 @@ var policyLintCmd = &cobra.Command{ }, Run: func(cmd *cobra.Command, args []string) { log.Info().Str("file", args[0]).Msg("lint policy bundle") + ensureProviders() files, err := policy.WalkPolicyBundleFiles(args[0]) if err != nil { @@ -135,6 +153,7 @@ var policyFmtCmd = &cobra.Command{ Short: "Apply style formatting to one or more policy bundles.", Args: cobra.MinimumNArgs(1), Run: func(cmd *cobra.Command, args []string) { + ensureProviders() for _, path := range args { err := bundle.FormatRecursive(path) if err != nil { @@ -163,6 +182,8 @@ var policyPublishCmd = &cobra.Command{ } config.DisplayUsedConfig() + ensureProviders() + filename := args[0] log.Info().Str("file", filename).Msg("load policy bundle") files, err := policy.WalkPolicyBundleFiles(args[0])