mirror of https://github.com/databricks/cli.git
230 lines
7.0 KiB
Go
Executable File
230 lines
7.0 KiB
Go
Executable File
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
|
|
|
|
package default_namespace
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/databricks/cli/cmd/root"
|
|
"github.com/databricks/cli/libs/cmdio"
|
|
"github.com/databricks/cli/libs/flags"
|
|
"github.com/databricks/databricks-sdk-go/service/settings"
|
|
"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: "default-namespace",
|
|
Short: `The default namespace setting API allows users to configure the default namespace for a Databricks workspace.`,
|
|
Long: `The default namespace setting API allows users to configure the default
|
|
namespace for a Databricks workspace.
|
|
|
|
Through this API, users can retrieve, set, or modify the default namespace
|
|
used when queries do not reference a fully qualified three-level name. For
|
|
example, if you use the API to set 'retail_prod' as the default catalog, then
|
|
a query 'SELECT * FROM myTable' would reference the object
|
|
'retail_prod.default.myTable' (the schema 'default' is always assumed).
|
|
|
|
This setting requires a restart of clusters and SQL warehouses to take effect.
|
|
Additionally, the default namespace only applies when using Unity
|
|
Catalog-enabled compute.`,
|
|
}
|
|
|
|
// Add methods
|
|
cmd.AddCommand(newDelete())
|
|
cmd.AddCommand(newGet())
|
|
cmd.AddCommand(newUpdate())
|
|
|
|
// Apply optional overrides to this command.
|
|
for _, fn := range cmdOverrides {
|
|
fn(cmd)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start delete 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 deleteOverrides []func(
|
|
*cobra.Command,
|
|
*settings.DeleteDefaultNamespaceSettingRequest,
|
|
)
|
|
|
|
func newDelete() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var deleteReq settings.DeleteDefaultNamespaceSettingRequest
|
|
|
|
// TODO: short flags
|
|
|
|
cmd.Flags().StringVar(&deleteReq.Etag, "etag", deleteReq.Etag, `etag used for versioning.`)
|
|
|
|
cmd.Use = "delete"
|
|
cmd.Short = `Delete the default namespace setting.`
|
|
cmd.Long = `Delete the default namespace setting.
|
|
|
|
Deletes the default namespace setting for the workspace. A fresh etag needs to
|
|
be provided in DELETE requests (as a query parameter). The etag can be
|
|
retrieved by making a GET request before the DELETE request. If the
|
|
setting is updated/deleted concurrently, DELETE fails with 409 and the
|
|
request must be retried by using the fresh etag in the 409 response.`
|
|
|
|
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, err := w.Settings.DefaultNamespace().Delete(ctx, deleteReq)
|
|
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 deleteOverrides {
|
|
fn(cmd, &deleteReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start get 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 getOverrides []func(
|
|
*cobra.Command,
|
|
*settings.GetDefaultNamespaceSettingRequest,
|
|
)
|
|
|
|
func newGet() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var getReq settings.GetDefaultNamespaceSettingRequest
|
|
|
|
// TODO: short flags
|
|
|
|
cmd.Flags().StringVar(&getReq.Etag, "etag", getReq.Etag, `etag used for versioning.`)
|
|
|
|
cmd.Use = "get"
|
|
cmd.Short = `Get the default namespace setting.`
|
|
cmd.Long = `Get the default namespace setting.
|
|
|
|
Gets the default namespace setting.`
|
|
|
|
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, err := w.Settings.DefaultNamespace().Get(ctx, getReq)
|
|
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 getOverrides {
|
|
fn(cmd, &getReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start update 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 updateOverrides []func(
|
|
*cobra.Command,
|
|
*settings.UpdateDefaultNamespaceSettingRequest,
|
|
)
|
|
|
|
func newUpdate() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var updateReq settings.UpdateDefaultNamespaceSettingRequest
|
|
var updateJson flags.JsonFlag
|
|
|
|
// TODO: short flags
|
|
cmd.Flags().Var(&updateJson, "json", `either inline JSON string or @path/to/file.json with request body`)
|
|
|
|
cmd.Use = "update"
|
|
cmd.Short = `Update the default namespace setting.`
|
|
cmd.Long = `Update the default namespace setting.
|
|
|
|
Updates the default namespace setting for the workspace. A fresh etag needs to
|
|
be provided in PATCH requests (as part of the setting field). The etag can
|
|
be retrieved by making a GET request before the PATCH request. Note that
|
|
if the setting does not exist, GET returns a NOT_FOUND error and the etag is
|
|
present in the error response, which should be set in the PATCH request. If
|
|
the setting is updated concurrently, PATCH fails with 409 and the request
|
|
must be retried by using the fresh etag in the 409 response.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.PreRunE = root.MustWorkspaceClient
|
|
cmd.RunE = func(cmd *cobra.Command, args []string) (err error) {
|
|
ctx := cmd.Context()
|
|
w := root.WorkspaceClient(ctx)
|
|
|
|
if cmd.Flags().Changed("json") {
|
|
err = updateJson.Unmarshal(&updateReq)
|
|
if err != nil {
|
|
return fmt.Errorf("failed to parse JSON string. Please ensure that the value provided to the --json flag is either a valid JSON string or @path/to/file.json with valid JSON content: %w", err)
|
|
}
|
|
} else {
|
|
return fmt.Errorf("please provide command input in JSON format by specifying the --json flag")
|
|
}
|
|
|
|
response, err := w.Settings.DefaultNamespace().Update(ctx, updateReq)
|
|
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 updateOverrides {
|
|
fn(cmd, &updateReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// end service DefaultNamespace
|