// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.

package resource_quotas

import (
	"github.com/databricks/cli/cmd/root"
	"github.com/databricks/cli/libs/cmdio"
	"github.com/databricks/databricks-sdk-go/service/catalog"
	"github.com/spf13/cobra"
)

// Slice with functions to override default command behavior.
// Functions can be added from the `init()` function in manually curated files in this directory.
var cmdOverrides []func(*cobra.Command)

func New() *cobra.Command {
	cmd := &cobra.Command{
		Use:   "resource-quotas",
		Short: `Unity Catalog enforces resource quotas on all securable objects, which limits the number of resources that can be created.`,
		Long: `Unity Catalog enforces resource quotas on all securable objects, which limits
  the number of resources that can be created. Quotas are expressed in terms of
  a resource type and a parent (for example, tables per metastore or schemas per
  catalog). The resource quota APIs enable you to monitor your current usage and
  limits. For more information on resource quotas see the [Unity Catalog
  documentation].
  
  [Unity Catalog documentation]: https://docs.databricks.com/en/data-governance/unity-catalog/index.html#resource-quotas`,
		GroupID: "catalog",
		Annotations: map[string]string{
			"package": "catalog",
		},
	}

	// Add methods
	cmd.AddCommand(newGetQuota())
	cmd.AddCommand(newListQuotas())

	// Apply optional overrides to this command.
	for _, fn := range cmdOverrides {
		fn(cmd)
	}

	return cmd
}

// start get-quota command

// Slice with functions to override default command behavior.
// Functions can be added from the `init()` function in manually curated files in this directory.
var getQuotaOverrides []func(
	*cobra.Command,
	*catalog.GetQuotaRequest,
)

func newGetQuota() *cobra.Command {
	cmd := &cobra.Command{}

	var getQuotaReq catalog.GetQuotaRequest

	// TODO: short flags

	cmd.Use = "get-quota PARENT_SECURABLE_TYPE PARENT_FULL_NAME QUOTA_NAME"
	cmd.Short = `Get information for a single resource quota.`
	cmd.Long = `Get information for a single resource quota.
  
  The GetQuota API returns usage information for a single resource quota,
  defined as a child-parent pair. This API also refreshes the quota count if it
  is out of date. Refreshes are triggered asynchronously. The updated count
  might not be returned in the first call.

  Arguments:
    PARENT_SECURABLE_TYPE: Securable type of the quota parent.
    PARENT_FULL_NAME: Full name of the parent resource. Provide the metastore ID if the parent
      is a metastore.
    QUOTA_NAME: Name of the quota. Follows the pattern of the quota type, with "-quota"
      added as a suffix.`

	cmd.Annotations = make(map[string]string)

	cmd.Args = func(cmd *cobra.Command, args []string) error {
		check := root.ExactArgs(3)
		return check(cmd, args)
	}

	cmd.PreRunE = root.MustWorkspaceClient
	cmd.RunE = func(cmd *cobra.Command, args []string) (err error) {
		ctx := cmd.Context()
		w := root.WorkspaceClient(ctx)

		getQuotaReq.ParentSecurableType = args[0]
		getQuotaReq.ParentFullName = args[1]
		getQuotaReq.QuotaName = args[2]

		response, err := w.ResourceQuotas.GetQuota(ctx, getQuotaReq)
		if err != nil {
			return err
		}
		return cmdio.Render(ctx, response)
	}

	// Disable completions since they are not applicable.
	// Can be overridden by manual implementation in `override.go`.
	cmd.ValidArgsFunction = cobra.NoFileCompletions

	// Apply optional overrides to this command.
	for _, fn := range getQuotaOverrides {
		fn(cmd, &getQuotaReq)
	}

	return cmd
}

// start list-quotas command

// Slice with functions to override default command behavior.
// Functions can be added from the `init()` function in manually curated files in this directory.
var listQuotasOverrides []func(
	*cobra.Command,
	*catalog.ListQuotasRequest,
)

func newListQuotas() *cobra.Command {
	cmd := &cobra.Command{}

	var listQuotasReq catalog.ListQuotasRequest

	// TODO: short flags

	cmd.Flags().IntVar(&listQuotasReq.MaxResults, "max-results", listQuotasReq.MaxResults, `The number of quotas to return.`)
	cmd.Flags().StringVar(&listQuotasReq.PageToken, "page-token", listQuotasReq.PageToken, `Opaque token for the next page of results.`)

	cmd.Use = "list-quotas"
	cmd.Short = `List all resource quotas under a metastore.`
	cmd.Long = `List all resource quotas under a metastore.
  
  ListQuotas returns all quota values under the metastore. There are no SLAs on
  the freshness of the counts returned. This API does not trigger a refresh of
  quota counts.`

	cmd.Annotations = make(map[string]string)

	cmd.Args = func(cmd *cobra.Command, args []string) error {
		check := root.ExactArgs(0)
		return check(cmd, args)
	}

	cmd.PreRunE = root.MustWorkspaceClient
	cmd.RunE = func(cmd *cobra.Command, args []string) (err error) {
		ctx := cmd.Context()
		w := root.WorkspaceClient(ctx)

		response := w.ResourceQuotas.ListQuotas(ctx, listQuotasReq)
		return cmdio.RenderIterator(ctx, response)
	}

	// Disable completions since they are not applicable.
	// Can be overridden by manual implementation in `override.go`.
	cmd.ValidArgsFunction = cobra.NoFileCompletions

	// Apply optional overrides to this command.
	for _, fn := range listQuotasOverrides {
		fn(cmd, &listQuotasReq)
	}

	return cmd
}

// end service ResourceQuotas