blob: 7b29ea19a5dac70efeccd68ce366aeb2803f1ec7 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.ambari.server.api.services;
import org.apache.ambari.server.api.resources.ResourceDefinition;
import org.apache.ambari.server.api.resources.ResourceInstance;
import org.apache.ambari.server.controller.spi.PageRequest;
import org.apache.ambari.server.controller.spi.Predicate;
import org.apache.ambari.server.controller.spi.TemporalInfo;
import java.util.List;
import java.util.Map;
/**
* Provides information on the current request.
*/
public interface Request {
/**
* Enum of request types.
*/
public enum Type {
GET,
POST,
PUT,
DELETE,
QUERY_POST
}
/**
* Process the request.
*
* @return the result
*/
public Result process();
/**
* Obtain the resource definition which corresponds to the resource being operated on by the request.
* The resource definition provides information about the resource type;
*
* @return the associated {@link ResourceDefinition}
*/
public ResourceInstance getResource();
/**
* Obtain the URI of this request.
*
* @return the request uri
*/
public String getURI();
/**
* Obtain the http request type. Type is one of {@link Type}.
*
* @return the http request type
*/
public Type getRequestType();
/**
* Obtain the api version of the request. The api version is specified in the request URI.
*
* @return the api version of the request
*/
public int getAPIVersion();
/**
* Obtain the query predicate that was built from the user provided predicate fields in the query string.
* If multiple predicates are supplied, then they will be combined using the appropriate logical grouping
* predicate such as 'AND'.
*
* @return the user defined predicate
*/
public Predicate getQueryPredicate();
/**
* Obtain the partial response fields and associated temporal information which were provided
* in the query string of the request uri.
*
* @return map of partial response propertyId to temporal information
*/
public Map<String, TemporalInfo> getFields();
/**
* Obtain the request body data.
*/
public RequestBody getBody();
/**
* Obtain the http headers associated with the request.
*
* @return the http headers
*/
public Map<String, List<String>> getHttpHeaders();
/**
* Obtain the pagination request information.
*
* @return the page request
*/
public PageRequest getPageRequest();
}