/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include namespace Aws { namespace Utils { namespace Xml { class XmlNode; } // namespace Xml } // namespace Utils namespace CloudSearch { namespace Model { /** *

Options for a search suggester.

See Also:

AWS * API Reference

*/ class DocumentSuggesterOptions { public: AWS_CLOUDSEARCH_API DocumentSuggesterOptions(); AWS_CLOUDSEARCH_API DocumentSuggesterOptions(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_CLOUDSEARCH_API DocumentSuggesterOptions& operator=(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_CLOUDSEARCH_API void OutputToStream(Aws::OStream& ostream, const char* location, unsigned index, const char* locationValue) const; AWS_CLOUDSEARCH_API void OutputToStream(Aws::OStream& oStream, const char* location) const; /** *

The name of the index field you want to use for suggestions.

*/ inline const Aws::String& GetSourceField() const{ return m_sourceField; } /** *

The name of the index field you want to use for suggestions.

*/ inline bool SourceFieldHasBeenSet() const { return m_sourceFieldHasBeenSet; } /** *

The name of the index field you want to use for suggestions.

*/ inline void SetSourceField(const Aws::String& value) { m_sourceFieldHasBeenSet = true; m_sourceField = value; } /** *

The name of the index field you want to use for suggestions.

*/ inline void SetSourceField(Aws::String&& value) { m_sourceFieldHasBeenSet = true; m_sourceField = std::move(value); } /** *

The name of the index field you want to use for suggestions.

*/ inline void SetSourceField(const char* value) { m_sourceFieldHasBeenSet = true; m_sourceField.assign(value); } /** *

The name of the index field you want to use for suggestions.

*/ inline DocumentSuggesterOptions& WithSourceField(const Aws::String& value) { SetSourceField(value); return *this;} /** *

The name of the index field you want to use for suggestions.

*/ inline DocumentSuggesterOptions& WithSourceField(Aws::String&& value) { SetSourceField(std::move(value)); return *this;} /** *

The name of the index field you want to use for suggestions.

*/ inline DocumentSuggesterOptions& WithSourceField(const char* value) { SetSourceField(value); return *this;} /** *

The level of fuzziness allowed when suggesting matches for a string: * none, low, or high. With none, the * specified string is treated as an exact prefix. With low, suggestions must * differ from the specified string by no more than one character. With high, * suggestions can differ by up to two characters. The default is none.

*/ inline const SuggesterFuzzyMatching& GetFuzzyMatching() const{ return m_fuzzyMatching; } /** *

The level of fuzziness allowed when suggesting matches for a string: * none, low, or high. With none, the * specified string is treated as an exact prefix. With low, suggestions must * differ from the specified string by no more than one character. With high, * suggestions can differ by up to two characters. The default is none.

*/ inline bool FuzzyMatchingHasBeenSet() const { return m_fuzzyMatchingHasBeenSet; } /** *

The level of fuzziness allowed when suggesting matches for a string: * none, low, or high. With none, the * specified string is treated as an exact prefix. With low, suggestions must * differ from the specified string by no more than one character. With high, * suggestions can differ by up to two characters. The default is none.

*/ inline void SetFuzzyMatching(const SuggesterFuzzyMatching& value) { m_fuzzyMatchingHasBeenSet = true; m_fuzzyMatching = value; } /** *

The level of fuzziness allowed when suggesting matches for a string: * none, low, or high. With none, the * specified string is treated as an exact prefix. With low, suggestions must * differ from the specified string by no more than one character. With high, * suggestions can differ by up to two characters. The default is none.

*/ inline void SetFuzzyMatching(SuggesterFuzzyMatching&& value) { m_fuzzyMatchingHasBeenSet = true; m_fuzzyMatching = std::move(value); } /** *

The level of fuzziness allowed when suggesting matches for a string: * none, low, or high. With none, the * specified string is treated as an exact prefix. With low, suggestions must * differ from the specified string by no more than one character. With high, * suggestions can differ by up to two characters. The default is none.

*/ inline DocumentSuggesterOptions& WithFuzzyMatching(const SuggesterFuzzyMatching& value) { SetFuzzyMatching(value); return *this;} /** *

The level of fuzziness allowed when suggesting matches for a string: * none, low, or high. With none, the * specified string is treated as an exact prefix. With low, suggestions must * differ from the specified string by no more than one character. With high, * suggestions can differ by up to two characters. The default is none.

*/ inline DocumentSuggesterOptions& WithFuzzyMatching(SuggesterFuzzyMatching&& value) { SetFuzzyMatching(std::move(value)); return *this;} /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline const Aws::String& GetSortExpression() const{ return m_sortExpression; } /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline bool SortExpressionHasBeenSet() const { return m_sortExpressionHasBeenSet; } /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline void SetSortExpression(const Aws::String& value) { m_sortExpressionHasBeenSet = true; m_sortExpression = value; } /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline void SetSortExpression(Aws::String&& value) { m_sortExpressionHasBeenSet = true; m_sortExpression = std::move(value); } /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline void SetSortExpression(const char* value) { m_sortExpressionHasBeenSet = true; m_sortExpression.assign(value); } /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline DocumentSuggesterOptions& WithSortExpression(const Aws::String& value) { SetSortExpression(value); return *this;} /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline DocumentSuggesterOptions& WithSortExpression(Aws::String&& value) { SetSortExpression(std::move(value)); return *this;} /** *

An expression that computes a score for each suggestion to control how they * are sorted. The scores are rounded to the nearest integer, with a floor of 0 and * a ceiling of 2^31-1. A document's relevance score is not computed for * suggestions, so sort expressions cannot reference the _score value. * To sort suggestions using a numeric field or existing expression, simply specify * the name of the field or expression. If no expression is configured for the * suggester, the suggestions are sorted with the closest matches listed first.

*/ inline DocumentSuggesterOptions& WithSortExpression(const char* value) { SetSortExpression(value); return *this;} private: Aws::String m_sourceField; bool m_sourceFieldHasBeenSet = false; SuggesterFuzzyMatching m_fuzzyMatching; bool m_fuzzyMatchingHasBeenSet = false; Aws::String m_sortExpression; bool m_sortExpressionHasBeenSet = false; }; } // namespace Model } // namespace CloudSearch } // namespace Aws