Container for the parameters to the DefineRankExpression operation.

Configures a RankExpression for the search domain. Used to create new rank expressions and modify existing ones. If the expression exists, the new configuration replaces the old one. You can configure a maximum of 50 rank expressions.

Inheritance: AmazonCloudSearchRequest
        /// <summary>
        /// <para>Configures a <c>RankExpression</c> for the search domain. Used to create new rank expressions and modify existing ones. If the
        /// expression exists, the new configuration replaces the old one. You can configure a maximum of 50 rank expressions.</para>
        /// </summary>
        /// 
        /// <param name="request">Container for the necessary parameters to execute the DefineRankExpression service method on
        /// AmazonCloudSearch.</param>
        /// 
        /// <returns>The response from the DefineRankExpression service method, as returned by AmazonCloudSearch.</returns>
        /// 
        /// <exception cref="T:Amazon.CloudSearch.Model.BaseException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.ResourceNotFoundException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.LimitExceededException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.InternalException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.InvalidTypeException" />
		public DefineRankExpressionResponse DefineRankExpression(DefineRankExpressionRequest request)
        {
            var task = DefineRankExpressionAsync(request);
            try
            {
                return task.Result;
            }
            catch(AggregateException e)
            {
                throw e.InnerException;
            }
        }
        /// <summary>
        /// Initiates the asynchronous execution of the DefineRankExpression operation.
        /// <seealso cref="Amazon.CloudSearch.IAmazonCloudSearch.DefineRankExpression"/>
        /// </summary>
        /// 
        /// <param name="request">Container for the necessary parameters to execute the DefineRankExpression operation.</param>
        /// <param name="cancellationToken">
        ///     A cancellation token that can be used by other objects or threads to receive notice of cancellation.
        /// </param>
        /// <returns>The task object representing the asynchronous operation.</returns>
		public async Task<DefineRankExpressionResponse> DefineRankExpressionAsync(DefineRankExpressionRequest request, CancellationToken cancellationToken = default(CancellationToken))
        {
            var marshaller = new DefineRankExpressionRequestMarshaller();
            var unmarshaller = DefineRankExpressionResponseUnmarshaller.GetInstance();
            var response = await Invoke<IRequest, DefineRankExpressionRequest, DefineRankExpressionResponse>(request, marshaller, unmarshaller, signer, cancellationToken)
                .ConfigureAwait(continueOnCapturedContext: false);
            return response;
        }
 /// <summary>
 /// <para>Configures a <c>RankExpression</c> for the search domain. Used to create new rank expressions and modify existing ones. If the
 /// expression exists, the new configuration replaces the old one. You can configure a maximum of 50 rank expressions.</para>
 /// </summary>
 /// 
 /// <param name="defineRankExpressionRequest">Container for the necessary parameters to execute the DefineRankExpression service method on
 ///          AmazonCloudSearch.</param>
 /// 
 /// <returns>The response from the DefineRankExpression service method, as returned by AmazonCloudSearch.</returns>
 /// 
 /// <exception cref="BaseException"/>
 /// <exception cref="ResourceNotFoundException"/>
 /// <exception cref="LimitExceededException"/>
 /// <exception cref="InternalException"/>
 /// <exception cref="InvalidTypeException"/>
 public DefineRankExpressionResponse DefineRankExpression(DefineRankExpressionRequest defineRankExpressionRequest)
 {
     IAsyncResult asyncResult = invokeDefineRankExpression(defineRankExpressionRequest, null, null, true);
     return EndDefineRankExpression(asyncResult);
 }
 /// <summary>
 /// Initiates the asynchronous execution of the DefineRankExpression operation.
 /// <seealso cref="Amazon.CloudSearch.AmazonCloudSearch.DefineRankExpression"/>
 /// </summary>
 /// 
 /// <param name="defineRankExpressionRequest">Container for the necessary parameters to execute the DefineRankExpression operation on
 ///          AmazonCloudSearch.</param>
 /// <param name="callback">An AsyncCallback delegate that is invoked when the operation completes.</param>
 /// <param name="state">A user-defined state object that is passed to the callback procedure. Retrieve this object from within the callback
 ///          procedure using the AsyncState property.</param>
 /// 
 /// <returns>An IAsyncResult that can be used to poll or wait for results, or both; this value is also needed when invoking
 ///         EndDefineRankExpression operation.</returns>
 public IAsyncResult BeginDefineRankExpression(DefineRankExpressionRequest defineRankExpressionRequest, AsyncCallback callback, object state)
 {
     return invokeDefineRankExpression(defineRankExpressionRequest, callback, state, false);
 }
 IAsyncResult invokeDefineRankExpression(DefineRankExpressionRequest defineRankExpressionRequest, AsyncCallback callback, object state, bool synchronized)
 {
     IRequest irequest = new DefineRankExpressionRequestMarshaller().Marshall(defineRankExpressionRequest);
     var unmarshaller = DefineRankExpressionResponseUnmarshaller.GetInstance();
     AsyncResult result = new AsyncResult(irequest, callback, state, synchronized, signer, unmarshaller);
     Invoke(result);
     return result;
 }
        /// <summary>
        /// Initiates the asynchronous execution of the DefineRankExpression operation.
        /// <seealso cref="Amazon.CloudSearch.IAmazonCloudSearch.DefineRankExpression"/>
        /// </summary>
        /// 
        /// <param name="request">Container for the necessary parameters to execute the DefineRankExpression operation.</param>
        /// <param name="cancellationToken">
        ///     A cancellation token that can be used by other objects or threads to receive notice of cancellation.
        /// </param>
        /// <returns>The task object representing the asynchronous operation.</returns>
		public Task<DefineRankExpressionResponse> DefineRankExpressionAsync(DefineRankExpressionRequest request, CancellationToken cancellationToken = default(CancellationToken))
        {
            var marshaller = new DefineRankExpressionRequestMarshaller();
            var unmarshaller = DefineRankExpressionResponseUnmarshaller.GetInstance();
            return Invoke<IRequest, DefineRankExpressionRequest, DefineRankExpressionResponse>(request, marshaller, unmarshaller, signer, cancellationToken);
        }
        /// <summary>
        /// <para>Configures a <c>RankExpression</c> for the search domain. Used to create new rank expressions and modify existing ones. If the
        /// expression exists, the new configuration replaces the old one. You can configure a maximum of 50 rank expressions.</para>
        /// </summary>
        /// 
        /// <param name="request">Container for the necessary parameters to execute the DefineRankExpression service method on
        /// AmazonCloudSearch.</param>
        /// 
        /// <returns>The response from the DefineRankExpression service method, as returned by AmazonCloudSearch.</returns>
        /// 
        /// <exception cref="T:Amazon.CloudSearch.Model.BaseException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.ResourceNotFoundException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.LimitExceededException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.InternalException" />
        /// <exception cref="T:Amazon.CloudSearch.Model.InvalidTypeException" />
		public DefineRankExpressionResponse DefineRankExpression(DefineRankExpressionRequest request)
        {
            var task = DefineRankExpressionAsync(request);
            try
            {
                return task.Result;
            }
            catch(AggregateException e)
            {
                ExceptionDispatchInfo.Capture(e.InnerException).Throw();
                return null;
            }
        }