mirror of https://github.com/databricks/cli.git
751 lines
23 KiB
Go
Executable File
751 lines
23 KiB
Go
Executable File
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
|
|
|
|
package vector_search_indexes
|
|
|
|
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/vectorsearch"
|
|
"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: "vector-search-indexes",
|
|
Short: `**Index**: An efficient representation of your embedding vectors that supports real-time and efficient approximate nearest neighbor (ANN) search queries.`,
|
|
Long: `**Index**: An efficient representation of your embedding vectors that supports
|
|
real-time and efficient approximate nearest neighbor (ANN) search queries.
|
|
|
|
There are 2 types of Vector Search indexes: * **Delta Sync Index**: An index
|
|
that automatically syncs with a source Delta Table, automatically and
|
|
incrementally updating the index as the underlying data in the Delta Table
|
|
changes. * **Direct Vector Access Index**: An index that supports direct read
|
|
and write of vectors and metadata through our REST and SDK APIs. With this
|
|
model, the user manages index updates.`,
|
|
GroupID: "vectorsearch",
|
|
Annotations: map[string]string{
|
|
"package": "vectorsearch",
|
|
},
|
|
}
|
|
|
|
// Add methods
|
|
cmd.AddCommand(newCreateIndex())
|
|
cmd.AddCommand(newDeleteDataVectorIndex())
|
|
cmd.AddCommand(newDeleteIndex())
|
|
cmd.AddCommand(newGetIndex())
|
|
cmd.AddCommand(newListIndexes())
|
|
cmd.AddCommand(newQueryIndex())
|
|
cmd.AddCommand(newQueryNextPage())
|
|
cmd.AddCommand(newScanIndex())
|
|
cmd.AddCommand(newSyncIndex())
|
|
cmd.AddCommand(newUpsertDataVectorIndex())
|
|
|
|
// Apply optional overrides to this command.
|
|
for _, fn := range cmdOverrides {
|
|
fn(cmd)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start create-index 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 createIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.CreateVectorIndexRequest,
|
|
)
|
|
|
|
func newCreateIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var createIndexReq vectorsearch.CreateVectorIndexRequest
|
|
var createIndexJson flags.JsonFlag
|
|
|
|
// TODO: short flags
|
|
cmd.Flags().Var(&createIndexJson, "json", `either inline JSON string or @path/to/file.json with request body`)
|
|
|
|
// TODO: complex arg: delta_sync_index_spec
|
|
// TODO: complex arg: direct_access_index_spec
|
|
|
|
cmd.Use = "create-index NAME ENDPOINT_NAME PRIMARY_KEY INDEX_TYPE"
|
|
cmd.Short = `Create an index.`
|
|
cmd.Long = `Create an index.
|
|
|
|
Create a new index.
|
|
|
|
Arguments:
|
|
NAME: Name of the index
|
|
ENDPOINT_NAME: Name of the endpoint to be used for serving the index
|
|
PRIMARY_KEY: Primary key of the index
|
|
INDEX_TYPE: There are 2 types of Vector Search indexes:
|
|
|
|
- DELTA_SYNC: An index that automatically syncs with a source Delta
|
|
Table, automatically and incrementally updating the index as the
|
|
underlying data in the Delta Table changes. - DIRECT_ACCESS: An index
|
|
that supports direct read and write of vectors and metadata through our
|
|
REST and SDK APIs. With this model, the user manages index updates.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
if cmd.Flags().Changed("json") {
|
|
err := root.ExactArgs(0)(cmd, args)
|
|
if err != nil {
|
|
return fmt.Errorf("when --json flag is specified, no positional arguments are required. Provide 'name', 'endpoint_name', 'primary_key', 'index_type' in your JSON input")
|
|
}
|
|
return nil
|
|
}
|
|
check := root.ExactArgs(4)
|
|
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)
|
|
|
|
if cmd.Flags().Changed("json") {
|
|
err = createIndexJson.Unmarshal(&createIndexReq)
|
|
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)
|
|
}
|
|
}
|
|
if !cmd.Flags().Changed("json") {
|
|
createIndexReq.Name = args[0]
|
|
}
|
|
if !cmd.Flags().Changed("json") {
|
|
createIndexReq.EndpointName = args[1]
|
|
}
|
|
if !cmd.Flags().Changed("json") {
|
|
createIndexReq.PrimaryKey = args[2]
|
|
}
|
|
if !cmd.Flags().Changed("json") {
|
|
_, err = fmt.Sscan(args[3], &createIndexReq.IndexType)
|
|
if err != nil {
|
|
return fmt.Errorf("invalid INDEX_TYPE: %s", args[3])
|
|
}
|
|
}
|
|
|
|
response, err := w.VectorSearchIndexes.CreateIndex(ctx, createIndexReq)
|
|
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 createIndexOverrides {
|
|
fn(cmd, &createIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start delete-data-vector-index 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 deleteDataVectorIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.DeleteDataVectorIndexRequest,
|
|
)
|
|
|
|
func newDeleteDataVectorIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var deleteDataVectorIndexReq vectorsearch.DeleteDataVectorIndexRequest
|
|
var deleteDataVectorIndexJson flags.JsonFlag
|
|
|
|
// TODO: short flags
|
|
cmd.Flags().Var(&deleteDataVectorIndexJson, "json", `either inline JSON string or @path/to/file.json with request body`)
|
|
|
|
cmd.Use = "delete-data-vector-index INDEX_NAME"
|
|
cmd.Short = `Delete data from index.`
|
|
cmd.Long = `Delete data from index.
|
|
|
|
Handles the deletion of data from a specified vector index.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the vector index where data is to be deleted. Must be a Direct
|
|
Vector Access Index.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
if cmd.Flags().Changed("json") {
|
|
err = deleteDataVectorIndexJson.Unmarshal(&deleteDataVectorIndexReq)
|
|
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")
|
|
}
|
|
deleteDataVectorIndexReq.IndexName = args[0]
|
|
|
|
response, err := w.VectorSearchIndexes.DeleteDataVectorIndex(ctx, deleteDataVectorIndexReq)
|
|
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 deleteDataVectorIndexOverrides {
|
|
fn(cmd, &deleteDataVectorIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start delete-index 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 deleteIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.DeleteIndexRequest,
|
|
)
|
|
|
|
func newDeleteIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var deleteIndexReq vectorsearch.DeleteIndexRequest
|
|
|
|
// TODO: short flags
|
|
|
|
cmd.Use = "delete-index INDEX_NAME"
|
|
cmd.Short = `Delete an index.`
|
|
cmd.Long = `Delete an index.
|
|
|
|
Delete an index.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the index`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
deleteIndexReq.IndexName = args[0]
|
|
|
|
err = w.VectorSearchIndexes.DeleteIndex(ctx, deleteIndexReq)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// 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 deleteIndexOverrides {
|
|
fn(cmd, &deleteIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start get-index 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 getIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.GetIndexRequest,
|
|
)
|
|
|
|
func newGetIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var getIndexReq vectorsearch.GetIndexRequest
|
|
|
|
// TODO: short flags
|
|
|
|
cmd.Use = "get-index INDEX_NAME"
|
|
cmd.Short = `Get an index.`
|
|
cmd.Long = `Get an index.
|
|
|
|
Get an index.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the index`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
getIndexReq.IndexName = args[0]
|
|
|
|
response, err := w.VectorSearchIndexes.GetIndex(ctx, getIndexReq)
|
|
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 getIndexOverrides {
|
|
fn(cmd, &getIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start list-indexes 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 listIndexesOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.ListIndexesRequest,
|
|
)
|
|
|
|
func newListIndexes() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var listIndexesReq vectorsearch.ListIndexesRequest
|
|
|
|
// TODO: short flags
|
|
|
|
cmd.Flags().StringVar(&listIndexesReq.PageToken, "page-token", listIndexesReq.PageToken, `Token for pagination.`)
|
|
|
|
cmd.Use = "list-indexes ENDPOINT_NAME"
|
|
cmd.Short = `List indexes.`
|
|
cmd.Long = `List indexes.
|
|
|
|
List all indexes in the given endpoint.
|
|
|
|
Arguments:
|
|
ENDPOINT_NAME: Name of the endpoint`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
listIndexesReq.EndpointName = args[0]
|
|
|
|
response := w.VectorSearchIndexes.ListIndexes(ctx, listIndexesReq)
|
|
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 listIndexesOverrides {
|
|
fn(cmd, &listIndexesReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start query-index 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 queryIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.QueryVectorIndexRequest,
|
|
)
|
|
|
|
func newQueryIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var queryIndexReq vectorsearch.QueryVectorIndexRequest
|
|
var queryIndexJson flags.JsonFlag
|
|
|
|
// TODO: short flags
|
|
cmd.Flags().Var(&queryIndexJson, "json", `either inline JSON string or @path/to/file.json with request body`)
|
|
|
|
cmd.Flags().StringVar(&queryIndexReq.FiltersJson, "filters-json", queryIndexReq.FiltersJson, `JSON string representing query filters.`)
|
|
cmd.Flags().IntVar(&queryIndexReq.NumResults, "num-results", queryIndexReq.NumResults, `Number of results to return.`)
|
|
cmd.Flags().StringVar(&queryIndexReq.QueryText, "query-text", queryIndexReq.QueryText, `Query text.`)
|
|
cmd.Flags().StringVar(&queryIndexReq.QueryType, "query-type", queryIndexReq.QueryType, `The query type to use.`)
|
|
// TODO: array: query_vector
|
|
cmd.Flags().Float64Var(&queryIndexReq.ScoreThreshold, "score-threshold", queryIndexReq.ScoreThreshold, `Threshold for the approximate nearest neighbor search.`)
|
|
|
|
cmd.Use = "query-index INDEX_NAME"
|
|
cmd.Short = `Query an index.`
|
|
cmd.Long = `Query an index.
|
|
|
|
Query the specified vector index.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the vector index to query.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
if cmd.Flags().Changed("json") {
|
|
err = queryIndexJson.Unmarshal(&queryIndexReq)
|
|
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")
|
|
}
|
|
queryIndexReq.IndexName = args[0]
|
|
|
|
response, err := w.VectorSearchIndexes.QueryIndex(ctx, queryIndexReq)
|
|
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 queryIndexOverrides {
|
|
fn(cmd, &queryIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start query-next-page 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 queryNextPageOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.QueryVectorIndexNextPageRequest,
|
|
)
|
|
|
|
func newQueryNextPage() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var queryNextPageReq vectorsearch.QueryVectorIndexNextPageRequest
|
|
var queryNextPageJson flags.JsonFlag
|
|
|
|
// TODO: short flags
|
|
cmd.Flags().Var(&queryNextPageJson, "json", `either inline JSON string or @path/to/file.json with request body`)
|
|
|
|
cmd.Flags().StringVar(&queryNextPageReq.EndpointName, "endpoint-name", queryNextPageReq.EndpointName, `Name of the endpoint.`)
|
|
cmd.Flags().StringVar(&queryNextPageReq.PageToken, "page-token", queryNextPageReq.PageToken, `Page token returned from previous QueryVectorIndex or QueryVectorIndexNextPage API.`)
|
|
|
|
cmd.Use = "query-next-page INDEX_NAME"
|
|
cmd.Short = `Query next page.`
|
|
cmd.Long = `Query next page.
|
|
|
|
Use next_page_token returned from previous QueryVectorIndex or
|
|
QueryVectorIndexNextPage request to fetch next page of results.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the vector index to query.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
if cmd.Flags().Changed("json") {
|
|
err = queryNextPageJson.Unmarshal(&queryNextPageReq)
|
|
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)
|
|
}
|
|
}
|
|
queryNextPageReq.IndexName = args[0]
|
|
|
|
response, err := w.VectorSearchIndexes.QueryNextPage(ctx, queryNextPageReq)
|
|
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 queryNextPageOverrides {
|
|
fn(cmd, &queryNextPageReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start scan-index 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 scanIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.ScanVectorIndexRequest,
|
|
)
|
|
|
|
func newScanIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var scanIndexReq vectorsearch.ScanVectorIndexRequest
|
|
var scanIndexJson flags.JsonFlag
|
|
|
|
// TODO: short flags
|
|
cmd.Flags().Var(&scanIndexJson, "json", `either inline JSON string or @path/to/file.json with request body`)
|
|
|
|
cmd.Flags().StringVar(&scanIndexReq.LastPrimaryKey, "last-primary-key", scanIndexReq.LastPrimaryKey, `Primary key of the last entry returned in the previous scan.`)
|
|
cmd.Flags().IntVar(&scanIndexReq.NumResults, "num-results", scanIndexReq.NumResults, `Number of results to return.`)
|
|
|
|
cmd.Use = "scan-index INDEX_NAME"
|
|
cmd.Short = `Scan an index.`
|
|
cmd.Long = `Scan an index.
|
|
|
|
Scan the specified vector index and return the first num_results entries
|
|
after the exclusive primary_key.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the vector index to scan.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
if cmd.Flags().Changed("json") {
|
|
err = scanIndexJson.Unmarshal(&scanIndexReq)
|
|
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)
|
|
}
|
|
}
|
|
scanIndexReq.IndexName = args[0]
|
|
|
|
response, err := w.VectorSearchIndexes.ScanIndex(ctx, scanIndexReq)
|
|
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 scanIndexOverrides {
|
|
fn(cmd, &scanIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start sync-index 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 syncIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.SyncIndexRequest,
|
|
)
|
|
|
|
func newSyncIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var syncIndexReq vectorsearch.SyncIndexRequest
|
|
|
|
// TODO: short flags
|
|
|
|
cmd.Use = "sync-index INDEX_NAME"
|
|
cmd.Short = `Synchronize an index.`
|
|
cmd.Long = `Synchronize an index.
|
|
|
|
Triggers a synchronization process for a specified vector index.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the vector index to synchronize. Must be a Delta Sync Index.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
check := root.ExactArgs(1)
|
|
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)
|
|
|
|
syncIndexReq.IndexName = args[0]
|
|
|
|
err = w.VectorSearchIndexes.SyncIndex(ctx, syncIndexReq)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// 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 syncIndexOverrides {
|
|
fn(cmd, &syncIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// start upsert-data-vector-index 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 upsertDataVectorIndexOverrides []func(
|
|
*cobra.Command,
|
|
*vectorsearch.UpsertDataVectorIndexRequest,
|
|
)
|
|
|
|
func newUpsertDataVectorIndex() *cobra.Command {
|
|
cmd := &cobra.Command{}
|
|
|
|
var upsertDataVectorIndexReq vectorsearch.UpsertDataVectorIndexRequest
|
|
var upsertDataVectorIndexJson flags.JsonFlag
|
|
|
|
// TODO: short flags
|
|
cmd.Flags().Var(&upsertDataVectorIndexJson, "json", `either inline JSON string or @path/to/file.json with request body`)
|
|
|
|
cmd.Use = "upsert-data-vector-index INDEX_NAME INPUTS_JSON"
|
|
cmd.Short = `Upsert data into an index.`
|
|
cmd.Long = `Upsert data into an index.
|
|
|
|
Handles the upserting of data into a specified vector index.
|
|
|
|
Arguments:
|
|
INDEX_NAME: Name of the vector index where data is to be upserted. Must be a Direct
|
|
Vector Access Index.
|
|
INPUTS_JSON: JSON string representing the data to be upserted.`
|
|
|
|
cmd.Annotations = make(map[string]string)
|
|
|
|
cmd.Args = func(cmd *cobra.Command, args []string) error {
|
|
if cmd.Flags().Changed("json") {
|
|
err := root.ExactArgs(1)(cmd, args)
|
|
if err != nil {
|
|
return fmt.Errorf("when --json flag is specified, provide only INDEX_NAME as positional arguments. Provide 'inputs_json' in your JSON input")
|
|
}
|
|
return nil
|
|
}
|
|
check := root.ExactArgs(2)
|
|
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)
|
|
|
|
if cmd.Flags().Changed("json") {
|
|
err = upsertDataVectorIndexJson.Unmarshal(&upsertDataVectorIndexReq)
|
|
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)
|
|
}
|
|
}
|
|
upsertDataVectorIndexReq.IndexName = args[0]
|
|
if !cmd.Flags().Changed("json") {
|
|
upsertDataVectorIndexReq.InputsJson = args[1]
|
|
}
|
|
|
|
response, err := w.VectorSearchIndexes.UpsertDataVectorIndex(ctx, upsertDataVectorIndexReq)
|
|
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 upsertDataVectorIndexOverrides {
|
|
fn(cmd, &upsertDataVectorIndexReq)
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
// end service VectorSearchIndexes
|