submit

package
v8.13.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 11, 2024 License: Apache-2.0 Imports: 16 Imported by: 4

Documentation

Overview

Executes a search request asynchronously.

Index

Constants

This section is empty.

Variables

View Source
var ErrBuildPath = errors.New("cannot build path, check for missing path parameters")

ErrBuildPath is returned in case of missing parameters within the build of the request.

Functions

This section is empty.

Types

type NewSubmit

type NewSubmit func() *Submit

NewSubmit type alias for index.

func NewSubmitFunc

func NewSubmitFunc(tp elastictransport.Interface) NewSubmit

NewSubmitFunc returns a new instance of Submit with the provided transport. Used in the index of the library this allows to retrieve every apis in once place.

type Request

type Request struct {
	Aggregations map[string]types.Aggregations `json:"aggregations,omitempty"`
	Collapse     *types.FieldCollapse          `json:"collapse,omitempty"`
	// DocvalueFields Array of wildcard (*) patterns. The request returns doc values for field
	// names matching these patterns in the hits.fields property of the response.
	DocvalueFields []types.FieldAndFormat `json:"docvalue_fields,omitempty"`
	// Explain If true, returns detailed information about score computation as part of a
	// hit.
	Explain *bool `json:"explain,omitempty"`
	// Ext Configuration of search extensions defined by Elasticsearch plugins.
	Ext map[string]json.RawMessage `json:"ext,omitempty"`
	// Fields Array of wildcard (*) patterns. The request returns values for field names
	// matching these patterns in the hits.fields property of the response.
	Fields []types.FieldAndFormat `json:"fields,omitempty"`
	// From Starting document offset. By default, you cannot page through more than
	// 10,000
	// hits using the from and size parameters. To page through more hits, use the
	// search_after parameter.
	From      *int             `json:"from,omitempty"`
	Highlight *types.Highlight `json:"highlight,omitempty"`
	// IndicesBoost Boosts the _score of documents from specified indices.
	IndicesBoost []map[string]types.Float64 `json:"indices_boost,omitempty"`
	// Knn Defines the approximate kNN search to run.
	Knn []types.KnnQuery `json:"knn,omitempty"`
	// MinScore Minimum _score for matching documents. Documents with a lower _score are
	// not included in the search results.
	MinScore *types.Float64 `json:"min_score,omitempty"`
	// Pit Limits the search to a point in time (PIT). If you provide a PIT, you
	// cannot specify an <index> in the request path.
	Pit        *types.PointInTimeReference `json:"pit,omitempty"`
	PostFilter *types.Query                `json:"post_filter,omitempty"`
	Profile    *bool                       `json:"profile,omitempty"`
	// Query Defines the search definition using the Query DSL.
	Query   *types.Query    `json:"query,omitempty"`
	Rescore []types.Rescore `json:"rescore,omitempty"`
	// RuntimeMappings Defines one or more runtime fields in the search request. These fields take
	// precedence over mapped fields with the same name.
	RuntimeMappings types.RuntimeFields `json:"runtime_mappings,omitempty"`
	// ScriptFields Retrieve a script evaluation (based on different fields) for each hit.
	ScriptFields map[string]types.ScriptField `json:"script_fields,omitempty"`
	SearchAfter  []types.FieldValue           `json:"search_after,omitempty"`
	// SeqNoPrimaryTerm If true, returns sequence number and primary term of the last modification
	// of each hit. See Optimistic concurrency control.
	SeqNoPrimaryTerm *bool `json:"seq_no_primary_term,omitempty"`
	// Size The number of hits to return. By default, you cannot page through more
	// than 10,000 hits using the from and size parameters. To page through more
	// hits, use the search_after parameter.
	Size  *int                     `json:"size,omitempty"`
	Slice *types.SlicedScroll      `json:"slice,omitempty"`
	Sort  []types.SortCombinations `json:"sort,omitempty"`
	// Source_ Indicates which source fields are returned for matching documents. These
	// fields are returned in the hits._source property of the search response.
	Source_ types.SourceConfig `json:"_source,omitempty"`
	// Stats Stats groups to associate with the search. Each group maintains a statistics
	// aggregation for its associated searches. You can retrieve these stats using
	// the indices stats API.
	Stats []string `json:"stats,omitempty"`
	// StoredFields List of stored fields to return as part of a hit. If no fields are specified,
	// no stored fields are included in the response. If this field is specified,
	// the _source
	// parameter defaults to false. You can pass _source: true to return both source
	// fields
	// and stored fields in the search response.
	StoredFields []string         `json:"stored_fields,omitempty"`
	Suggest      *types.Suggester `json:"suggest,omitempty"`
	// TerminateAfter Maximum number of documents to collect for each shard. If a query reaches
	// this
	// limit, Elasticsearch terminates the query early. Elasticsearch collects
	// documents
	// before sorting. Defaults to 0, which does not terminate query execution
	// early.
	TerminateAfter *int64 `json:"terminate_after,omitempty"`
	// Timeout Specifies the period of time to wait for a response from each shard. If no
	// response
	// is received before the timeout expires, the request fails and returns an
	// error.
	// Defaults to no timeout.
	Timeout *string `json:"timeout,omitempty"`
	// TrackScores If true, calculate and return document scores, even if the scores are not
	// used for sorting.
	TrackScores *bool `json:"track_scores,omitempty"`
	// TrackTotalHits Number of hits matching the query to count accurately. If true, the exact
	// number of hits is returned at the cost of some performance. If false, the
	// response does not include the total number of hits matching the query.
	// Defaults to 10,000 hits.
	TrackTotalHits types.TrackHits `json:"track_total_hits,omitempty"`
	// Version If true, returns document version as part of a hit.
	Version *bool `json:"version,omitempty"`
}

Request holds the request body struct for the package submit

https://github.com/elastic/elasticsearch-specification/blob/5bf86339cd4bda77d07f6eaa6789b72f9c0279b1/specification/async_search/submit/AsyncSearchSubmitRequest.ts#L55-L286

func NewRequest added in v8.5.0

func NewRequest() *Request

NewRequest returns a Request

func (*Request) FromJSON added in v8.5.0

func (r *Request) FromJSON(data string) (*Request, error)

FromJSON allows to load an arbitrary json into the request structure

func (*Request) UnmarshalJSON added in v8.12.1

func (s *Request) UnmarshalJSON(data []byte) error

type Response added in v8.7.0

type Response struct {

	// CompletionTime Indicates when the async search completed. Only present
	// when the search has completed.
	CompletionTime         types.DateTime `json:"completion_time,omitempty"`
	CompletionTimeInMillis *int64         `json:"completion_time_in_millis,omitempty"`
	// ExpirationTime Indicates when the async search will expire.
	ExpirationTime         types.DateTime `json:"expiration_time,omitempty"`
	ExpirationTimeInMillis int64          `json:"expiration_time_in_millis"`
	Id                     *string        `json:"id,omitempty"`
	// IsPartial When the query is no longer running, this property indicates whether the
	// search failed or was successfully completed on all shards.
	// While the query is running, `is_partial` is always set to `true`.
	IsPartial bool `json:"is_partial"`
	// IsRunning Indicates whether the search is still running or has completed.
	// NOTE: If the search failed after some shards returned their results or the
	// node that is coordinating the async search dies, results may be partial even
	// though `is_running` is `false`.
	IsRunning         bool              `json:"is_running"`
	Response          types.AsyncSearch `json:"response"`
	StartTime         types.DateTime    `json:"start_time,omitempty"`
	StartTimeInMillis int64             `json:"start_time_in_millis"`
}

Response holds the response body struct for the package submit

https://github.com/elastic/elasticsearch-specification/blob/5bf86339cd4bda77d07f6eaa6789b72f9c0279b1/specification/async_search/submit/AsyncSearchSubmitResponse.ts#L22-L24

func NewResponse added in v8.7.0

func NewResponse() *Response

NewResponse returns a Response

type Submit

type Submit struct {
	// contains filtered or unexported fields
}

func (*Submit) Aggregations added in v8.9.0

func (r *Submit) Aggregations(aggregations map[string]types.Aggregations) *Submit

API name: aggregations

func (*Submit) AllowNoIndices

func (r *Submit) AllowNoIndices(allownoindices bool) *Submit

AllowNoIndices Whether to ignore if a wildcard indices expression resolves into no concrete indices. (This includes `_all` string or when no indices have been specified) API name: allow_no_indices

func (*Submit) AllowPartialSearchResults

func (r *Submit) AllowPartialSearchResults(allowpartialsearchresults bool) *Submit

AllowPartialSearchResults Indicate if an error should be returned if there is a partial search failure or timeout API name: allow_partial_search_results

func (*Submit) AnalyzeWildcard

func (r *Submit) AnalyzeWildcard(analyzewildcard bool) *Submit

AnalyzeWildcard Specify whether wildcard and prefix queries should be analyzed (default: false) API name: analyze_wildcard

func (*Submit) Analyzer

func (r *Submit) Analyzer(analyzer string) *Submit

Analyzer The analyzer to use for the query string API name: analyzer

func (*Submit) BatchedReduceSize

func (r *Submit) BatchedReduceSize(batchedreducesize string) *Submit

BatchedReduceSize Affects how often partial results become available, which happens whenever shard results are reduced. A partial reduction is performed every time the coordinating node has received a certain number of new shard responses (5 by default). API name: batched_reduce_size

func (*Submit) CcsMinimizeRoundtrips

func (r *Submit) CcsMinimizeRoundtrips(ccsminimizeroundtrips bool) *Submit

CcsMinimizeRoundtrips The default value is the only supported value. API name: ccs_minimize_roundtrips

func (*Submit) Collapse added in v8.9.0

func (r *Submit) Collapse(collapse *types.FieldCollapse) *Submit

API name: collapse

func (*Submit) DefaultOperator

func (r *Submit) DefaultOperator(defaultoperator operator.Operator) *Submit

DefaultOperator The default operator for query string query (AND or OR) API name: default_operator

func (*Submit) Df

func (r *Submit) Df(df string) *Submit

Df The field to use as default where no field prefix is given in the query string API name: df

func (Submit) Do

func (r Submit) Do(providedCtx context.Context) (*Response, error)

Do runs the request through the transport, handle the response and returns a submit.Response

func (*Submit) DocvalueFields

func (r *Submit) DocvalueFields(docvaluefields ...types.FieldAndFormat) *Submit

DocvalueFields Array of wildcard (*) patterns. The request returns doc values for field names matching these patterns in the hits.fields property of the response. API name: docvalue_fields

func (*Submit) ExpandWildcards

func (r *Submit) ExpandWildcards(expandwildcards ...expandwildcard.ExpandWildcard) *Submit

ExpandWildcards Whether to expand wildcard expression to concrete indices that are open, closed or both. API name: expand_wildcards

func (*Submit) Explain

func (r *Submit) Explain(explain bool) *Submit

Explain If true, returns detailed information about score computation as part of a hit. API name: explain

func (*Submit) Ext added in v8.9.0

func (r *Submit) Ext(ext map[string]json.RawMessage) *Submit

Ext Configuration of search extensions defined by Elasticsearch plugins. API name: ext

func (*Submit) Fields added in v8.9.0

func (r *Submit) Fields(fields ...types.FieldAndFormat) *Submit

Fields Array of wildcard (*) patterns. The request returns values for field names matching these patterns in the hits.fields property of the response. API name: fields

func (*Submit) From

func (r *Submit) From(from int) *Submit

From Starting document offset. By default, you cannot page through more than 10,000 hits using the from and size parameters. To page through more hits, use the search_after parameter. API name: from

func (*Submit) Header

func (r *Submit) Header(key, value string) *Submit

Header set a key, value pair in the Submit headers map.

func (*Submit) Highlight added in v8.9.0

func (r *Submit) Highlight(highlight *types.Highlight) *Submit

API name: highlight

func (*Submit) HttpRequest

func (r *Submit) HttpRequest(ctx context.Context) (*http.Request, error)

HttpRequest returns the http.Request object built from the given parameters.

func (*Submit) IgnoreThrottled

func (r *Submit) IgnoreThrottled(ignorethrottled bool) *Submit

IgnoreThrottled Whether specified concrete, expanded or aliased indices should be ignored when throttled API name: ignore_throttled

func (*Submit) IgnoreUnavailable

func (r *Submit) IgnoreUnavailable(ignoreunavailable bool) *Submit

IgnoreUnavailable Whether specified concrete indices should be ignored when unavailable (missing or closed) API name: ignore_unavailable

func (*Submit) Index

func (r *Submit) Index(index string) *Submit

Index A comma-separated list of index names to search; use `_all` or empty string to perform the operation on all indices API Name: index

func (*Submit) IndicesBoost added in v8.9.0

func (r *Submit) IndicesBoost(indicesboosts ...map[string]types.Float64) *Submit

IndicesBoost Boosts the _score of documents from specified indices. API name: indices_boost

func (*Submit) KeepAlive

func (r *Submit) KeepAlive(duration string) *Submit

KeepAlive Specifies how long the async search needs to be available. Ongoing async searches and any saved search results are deleted after this period. API name: keep_alive

func (*Submit) KeepOnCompletion

func (r *Submit) KeepOnCompletion(keeponcompletion bool) *Submit

KeepOnCompletion If `true`, results are stored for later retrieval when the search completes within the `wait_for_completion_timeout`. API name: keep_on_completion

func (*Submit) Knn added in v8.9.0

func (r *Submit) Knn(knns ...types.KnnQuery) *Submit

Knn Defines the approximate kNN search to run. API name: knn

func (*Submit) Lenient

func (r *Submit) Lenient(lenient bool) *Submit

Lenient Specify whether format-based query failures (such as providing text to a numeric field) should be ignored API name: lenient

func (*Submit) MaxConcurrentShardRequests

func (r *Submit) MaxConcurrentShardRequests(maxconcurrentshardrequests string) *Submit

MaxConcurrentShardRequests The number of concurrent shard requests per node this search executes concurrently. This value should be used to limit the impact of the search on the cluster in order to limit the number of concurrent shard requests API name: max_concurrent_shard_requests

func (*Submit) MinCompatibleShardNode

func (r *Submit) MinCompatibleShardNode(versionstring string) *Submit

API name: min_compatible_shard_node

func (*Submit) MinScore added in v8.9.0

func (r *Submit) MinScore(minscore types.Float64) *Submit

MinScore Minimum _score for matching documents. Documents with a lower _score are not included in the search results. API name: min_score

func (Submit) Perform added in v8.7.0

func (r Submit) Perform(providedCtx context.Context) (*http.Response, error)

Perform runs the http.Request through the provided transport and returns an http.Response.

func (*Submit) Pit added in v8.9.0

func (r *Submit) Pit(pit *types.PointInTimeReference) *Submit

Pit Limits the search to a point in time (PIT). If you provide a PIT, you cannot specify an <index> in the request path. API name: pit

func (*Submit) PostFilter added in v8.9.0

func (r *Submit) PostFilter(postfilter *types.Query) *Submit

API name: post_filter

func (*Submit) PreFilterShardSize

func (r *Submit) PreFilterShardSize(prefiltershardsize string) *Submit

PreFilterShardSize The default value cannot be changed, which enforces the execution of a pre-filter roundtrip to retrieve statistics from each shard so that the ones that surely don’t hold any document matching the query get skipped. API name: pre_filter_shard_size

func (*Submit) Preference

func (r *Submit) Preference(preference string) *Submit

Preference Specify the node or shard the operation should be performed on (default: random) API name: preference

func (*Submit) Profile added in v8.9.0

func (r *Submit) Profile(profile bool) *Submit

API name: profile

func (*Submit) Q

func (r *Submit) Q(q string) *Submit

Q Query in the Lucene query string syntax API name: q

func (*Submit) Query added in v8.9.0

func (r *Submit) Query(query *types.Query) *Submit

Query Defines the search definition using the Query DSL. API name: query

func (*Submit) Raw

func (r *Submit) Raw(raw io.Reader) *Submit

Raw takes a json payload as input which is then passed to the http.Request If specified Raw takes precedence on Request method.

func (*Submit) Request

func (r *Submit) Request(req *Request) *Submit

Request allows to set the request property with the appropriate payload.

func (*Submit) RequestCache

func (r *Submit) RequestCache(requestcache bool) *Submit

RequestCache Specify if request cache should be used for this request or not, defaults to true API name: request_cache

func (*Submit) Rescore added in v8.9.0

func (r *Submit) Rescore(rescores ...types.Rescore) *Submit

API name: rescore

func (*Submit) RestTotalHitsAsInt

func (r *Submit) RestTotalHitsAsInt(resttotalhitsasint bool) *Submit

API name: rest_total_hits_as_int

func (*Submit) Routing

func (r *Submit) Routing(routing string) *Submit

Routing A comma-separated list of specific routing values API name: routing

func (*Submit) RuntimeMappings added in v8.9.0

func (r *Submit) RuntimeMappings(runtimefields types.RuntimeFields) *Submit

RuntimeMappings Defines one or more runtime fields in the search request. These fields take precedence over mapped fields with the same name. API name: runtime_mappings

func (*Submit) ScriptFields added in v8.9.0

func (r *Submit) ScriptFields(scriptfields map[string]types.ScriptField) *Submit

ScriptFields Retrieve a script evaluation (based on different fields) for each hit. API name: script_fields

func (*Submit) Scroll

func (r *Submit) Scroll(duration string) *Submit

API name: scroll

func (*Submit) SearchAfter added in v8.9.0

func (r *Submit) SearchAfter(sortresults ...types.FieldValue) *Submit

API name: search_after

func (*Submit) SearchType

func (r *Submit) SearchType(searchtype searchtype.SearchType) *Submit

SearchType Search operation type API name: search_type

func (*Submit) SeqNoPrimaryTerm

func (r *Submit) SeqNoPrimaryTerm(seqnoprimaryterm bool) *Submit

SeqNoPrimaryTerm If true, returns sequence number and primary term of the last modification of each hit. See Optimistic concurrency control. API name: seq_no_primary_term

func (*Submit) Size

func (r *Submit) Size(size int) *Submit

Size The number of hits to return. By default, you cannot page through more than 10,000 hits using the from and size parameters. To page through more hits, use the search_after parameter. API name: size

func (*Submit) Slice added in v8.9.0

func (r *Submit) Slice(slice *types.SlicedScroll) *Submit

API name: slice

func (*Submit) Sort

func (r *Submit) Sort(sorts ...types.SortCombinations) *Submit

API name: sort

func (*Submit) SourceExcludes_

func (r *Submit) SourceExcludes_(fields ...string) *Submit

SourceExcludes_ A list of fields to exclude from the returned _source field API name: _source_excludes

func (*Submit) SourceIncludes_

func (r *Submit) SourceIncludes_(fields ...string) *Submit

SourceIncludes_ A list of fields to extract and return from the _source field API name: _source_includes

func (*Submit) Source_

func (r *Submit) Source_(sourceconfig types.SourceConfig) *Submit

Source_ Indicates which source fields are returned for matching documents. These fields are returned in the hits._source property of the search response. API name: _source

func (*Submit) Stats

func (r *Submit) Stats(stats ...string) *Submit

Stats Stats groups to associate with the search. Each group maintains a statistics aggregation for its associated searches. You can retrieve these stats using the indices stats API. API name: stats

func (*Submit) StoredFields

func (r *Submit) StoredFields(fields ...string) *Submit

StoredFields List of stored fields to return as part of a hit. If no fields are specified, no stored fields are included in the response. If this field is specified, the _source parameter defaults to false. You can pass _source: true to return both source fields and stored fields in the search response. API name: stored_fields

func (*Submit) Suggest added in v8.9.0

func (r *Submit) Suggest(suggest *types.Suggester) *Submit

API name: suggest

func (*Submit) SuggestField

func (r *Submit) SuggestField(field string) *Submit

SuggestField Specifies which field to use for suggestions. API name: suggest_field

func (*Submit) SuggestMode

func (r *Submit) SuggestMode(suggestmode suggestmode.SuggestMode) *Submit

SuggestMode Specify suggest mode API name: suggest_mode

func (*Submit) SuggestSize

func (r *Submit) SuggestSize(suggestsize string) *Submit

SuggestSize How many suggestions to return in response API name: suggest_size

func (*Submit) SuggestText

func (r *Submit) SuggestText(suggesttext string) *Submit

SuggestText The source text for which the suggestions should be returned. API name: suggest_text

func (*Submit) TerminateAfter

func (r *Submit) TerminateAfter(terminateafter int64) *Submit

TerminateAfter Maximum number of documents to collect for each shard. If a query reaches this limit, Elasticsearch terminates the query early. Elasticsearch collects documents before sorting. Defaults to 0, which does not terminate query execution early. API name: terminate_after

func (*Submit) Timeout

func (r *Submit) Timeout(timeout string) *Submit

Timeout Specifies the period of time to wait for a response from each shard. If no response is received before the timeout expires, the request fails and returns an error. Defaults to no timeout. API name: timeout

func (*Submit) TrackScores

func (r *Submit) TrackScores(trackscores bool) *Submit

TrackScores If true, calculate and return document scores, even if the scores are not used for sorting. API name: track_scores

func (*Submit) TrackTotalHits

func (r *Submit) TrackTotalHits(trackhits types.TrackHits) *Submit

TrackTotalHits Number of hits matching the query to count accurately. If true, the exact number of hits is returned at the cost of some performance. If false, the response does not include the total number of hits matching the query. Defaults to 10,000 hits. API name: track_total_hits

func (*Submit) TypedKeys

func (r *Submit) TypedKeys(typedkeys bool) *Submit

TypedKeys Specify whether aggregation and suggester names should be prefixed by their respective types in the response API name: typed_keys

func (*Submit) Version

func (r *Submit) Version(version bool) *Submit

Version If true, returns document version as part of a hit. API name: version

func (*Submit) WaitForCompletionTimeout

func (r *Submit) WaitForCompletionTimeout(duration string) *Submit

WaitForCompletionTimeout Blocks and waits until the search is completed up to a certain timeout. When the async search completes within the timeout, the response won’t include the ID as the results are not stored in the cluster. API name: wait_for_completion_timeout

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL