org.eclipse.microprofile.openapi.models.PathItem Maven / Gradle / Ivy
/**
* Copyright (c) 2017 Contributors to the Eclipse Foundation
* Copyright 2017 SmartBear Software
*
* Licensed 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.eclipse.microprofile.openapi.models;
import java.util.List;
import java.util.Map;
import org.eclipse.microprofile.openapi.models.parameters.Parameter;
import org.eclipse.microprofile.openapi.models.servers.Server;
/**
* PathItem
*
* Describes the operations available on a single path. A Path Item MAY be empty, due to
* security
* constraints. In that case the path itself is still exposed to the documentation viewer but you will not know
* which operations and parameters are available.
*
*
* @see OpenAPI
* Specification Path Item Object
*/
public interface PathItem extends Constructible, Extensible, Reference {
/**
* All of the possible types of HTTP operations for this path
**/
enum HttpMethod {
POST, GET, PUT, PATCH, DELETE, HEAD, OPTIONS, TRACE
}
/**
* Returns the summary property from a PathItem instance.
*
* @return a short summary of what the path item represents
**/
String getSummary();
/**
* Sets this PathItem's summary property to the given string.
*
* @param summary
* short summary of what the path item represents
**/
void setSummary(String summary);
/**
* Sets this PathItem's summary property to the given string.
*
* @param summary
* short summary of what the path item represents
* @return the current PathItem instance
**/
default PathItem summary(String summary) {
setSummary(summary);
return this;
}
/**
* Returns the description property from a PathItem instance.
*
* @return a detailed description of what the path item represents
**/
String getDescription();
/**
* Sets this PathItem's description property to the given string.
*
* @param description
* detailed description of what the path item represents
**/
void setDescription(String description);
/**
* Sets this PathItem's description property to the given string.
*
* @param description
* detailed description of what the path item represents
* @return the current PathItem instance
**/
default PathItem description(String description) {
setDescription(description);
return this;
}
/**
* Returns the get property from a PathItem instance.
*
* @return definition of a GET operation on this path
**/
Operation getGET();
/**
* Sets this PathItem's get property to the given operation.
*
* @param get
* definition of a GET operation
**/
void setGET(Operation get);
/**
* Sets this PathItem's get property to the given operation.
*
* @param get
* definition of a GET operation
* @return the current PathItem instance
**/
default PathItem GET(Operation get) {
setGET(get);
return this;
}
/**
* Returns the put property from a PathItem instance.
*
* @return definition of a PUT operation on this path
**/
Operation getPUT();
/**
* Sets this PathItem's put property to the given operation.
*
* @param put
* definition of a PUT operation
**/
void setPUT(Operation put);
/**
* Sets this PathItem's put property to the given operation.
*
* @param put
* definition of a PUT operation
* @return the current PathItem instance
**/
default PathItem PUT(Operation put) {
setPUT(put);
return this;
}
/**
* Returns the post property from a PathItem instance.
*
* @return definition of a POST operation on this path
**/
Operation getPOST();
/**
* Sets this PathItem's post property to the given operation.
*
* @param post
* definition of a PUT operation
**/
void setPOST(Operation post);
/**
* Sets this PathItem's post property to the given operation.
*
* @param post
* definition of a PUT operation
* @return the current PathItem instance
**/
default PathItem POST(Operation post) {
setPOST(post);
return this;
}
/**
* Returns the delete property from a PathItem instance.
*
* @return definition of a DELETE operation on this path
**/
Operation getDELETE();
/**
* Sets this PathItem's delete property to the given operation.
*
* @param delete
* definition of a DELETE operation
**/
void setDELETE(Operation delete);
/**
* Sets this PathItem's delete property to the given operation.
*
* @param delete
* definition of a DELETE operation
* @return the current PathItem instance
**/
default PathItem DELETE(Operation delete) {
setDELETE(delete);
return this;
}
/**
* Returns the options property from a PathItem instance.
*
* @return definition of an OPTIONS operation on this path
**/
Operation getOPTIONS();
/**
* Sets this PathItem's options property to the given operation.
*
* @param options
* definition of an OPTIONS operation
**/
void setOPTIONS(Operation options);
/**
* Sets this PathItem's options property to the given operation.
*
* @param options
* definition of an OPTIONS operation
* @return the current PathItem instance
**/
default PathItem OPTIONS(Operation options) {
setOPTIONS(options);
return this;
}
/**
* Returns the head property from a PathItem instance.
*
* @return definition of a HEAD operation on this path
**/
Operation getHEAD();
/**
* Sets this PathItem's head property to the given operation.
*
* @param head
* definition of a HEAD operation
**/
void setHEAD(Operation head);
/**
* Sets this PathItem's head property to the given operation.
*
* @param head
* definition of a HEAD operation
* @return the current PathItem instance
**/
default PathItem HEAD(Operation head) {
setHEAD(head);
return this;
}
/**
* Returns the patch property from a PathItem instance.
*
* @return definition of a PATCH operation on this path
**/
Operation getPATCH();
/**
* Sets this PathItem's patch property to the given operation.
*
* @param patch
* definition of a PATCH operation
**/
void setPATCH(Operation patch);
/**
* Sets this PathItem's patch property to the given operation.
*
* @param patch
* definition of a PATCH operation
* @return the current PathItem instance
**/
default PathItem PATCH(Operation patch) {
setPATCH(patch);
return this;
}
/**
* Returns the trace property from a PathItem instance.
*
* @return definition of a TRACE operation on this path
**/
Operation getTRACE();
/**
* Sets this PathItem's trace property to the given operation.
*
* @param trace
* definition of a TRACE operation
**/
void setTRACE(Operation trace);
/**
* Sets this PathItem's trace property to the given operation.
*
* @param trace
* definition of a TRACE operation
* @return the current PathItem instance
**/
default PathItem TRACE(Operation trace) {
setTRACE(trace);
return this;
}
/**
* Returns a map with all the operations for this path where the keys are {@link PathItem.HttpMethod} items
*
* @return a map with all the operations for this path where the keys are HttpMethods
**/
Map getOperations();
/**
* Sets an operation for a given http method.
*
* @param httpMethod
* the http method
* @param operation
* the definition of an operation for the given http method.
*/
void setOperation(PathItem.HttpMethod httpMethod, Operation operation);
/**
* Returns the servers property from a PathItem instance.
*
* @return a copy List (potentially immutable) of all the servers defined in this path item
**/
List getServers();
/**
* Sets this PathItem's servers property to the given list.
*
* @param servers
* a list of the servers to service operations in this path item
**/
void setServers(List servers);
/**
* Sets this PathItem's servers property to the given list.
*
* @param servers
* a list of the servers to service operations in this path item
* @return the current PathItem instance
**/
default PathItem servers(List servers) {
setServers(servers);
return this;
}
/**
* Adds the given server to this PathItem's list of servers.
*
* @param server
* a server to service operations in this path item
* @return the current PathItem instance
**/
PathItem addServer(Server server);
/**
* Removes the given server to this PathItem's list of servers.
*
* @param server
* a server to service operations in this path item
**/
void removeServer(Server server);
/**
* Returns the parameters property from this PathItem instance.
*
* @return a copy List (potentially immutable) of parameters that are applicable to all the operations described
* under this path
**/
List getParameters();
/**
* Sets this PathItem's parameters property to the given list.
*
* @param parameters
* a list of parameters that are applicable to all the operations described under this path
**/
void setParameters(List parameters);
/**
* Sets this PathItem's parameters property to the given list.
*
* @param parameters
* a list of parameters that are applicable to all the operations described under this path
* @return the current PathItem instance
**/
default PathItem parameters(List parameters) {
setParameters(parameters);
return this;
}
/**
* Adds the given parameter to this PathItem's list of parameters.
*
* @param parameter
* a parameter that is applicable to all the operations described under this path
* @return the current PathItem instance
**/
PathItem addParameter(Parameter parameter);
/**
* Removes the given parameter to this PathItem's list of parameters.
*
* @param parameter
* a parameter that is applicable to all the operations described under this path
**/
void removeParameter(Parameter parameter);
}