org.eclipse.microprofile.openapi.models.Operation 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.callbacks.Callback;
import org.eclipse.microprofile.openapi.models.parameters.Parameter;
import org.eclipse.microprofile.openapi.models.parameters.RequestBody;
import org.eclipse.microprofile.openapi.models.responses.APIResponses;
import org.eclipse.microprofile.openapi.models.security.SecurityRequirement;
import org.eclipse.microprofile.openapi.models.servers.Server;
/**
* Operation
*
* Describes a single API operation on a path.
*
*
* @see OpenAPI
* Specification Operation Object
*/
public interface Operation extends Constructible, Extensible {
/**
* Returns the tags property from an Operation instance.
*
* @return a copy List (potentially immutable) of the operation's tags
**/
List getTags();
/**
* Sets this Operation's tags property to the given tags.
*
* @param tags
* a list of tags for API documentation control
**/
void setTags(List tags);
/**
* Sets this Operation's tags property to the given tags.
*
* @param tags
* a list of tags for API documentation control
* @return the current Operation object
**/
default Operation tags(List tags) {
setTags(tags);
return this;
}
/**
* Adds the given tag to this Operation's list of tags.
*
* @param tag
* a tag for API documentation control
* @return the current Operation object
**/
Operation addTag(String tag);
/**
* Removes the given tag to this Operation's list of tags.
*
* @param tag
* a tag for API documentation control
**/
void removeTag(String tag);
/**
* Returns the summary property from an Operation instance.
*
* @return a short summary of what the operation does
**/
String getSummary();
/**
* Sets this Operation's summary property to the given string.
*
* @param summary
* a short summary of what the operation does
**/
void setSummary(String summary);
/**
* Sets this Operation's summary property to the given string.
*
* @param summary
* a short summary of what the operation does
* @return the current Operation object
**/
default Operation summary(String summary) {
setSummary(summary);
return this;
}
/**
* Returns the description property from an Operation instance.
*
* @return a verbose explanation of the operation behavior
**/
String getDescription();
/**
* Sets this Operation's description property to the given string.
*
* @param description
* a verbose explanation of the operation behavior
**/
void setDescription(String description);
/**
* Sets this Operation's description property to the given string.
*
* @param description
* a verbose explanation of the operation behavior
* @return the current Operation object
**/
default Operation description(String description) {
setDescription(description);
return this;
}
/**
* Returns the externalDocs property from an Operation instance.
*
* @return additional external documentation for this operation
**/
ExternalDocumentation getExternalDocs();
/**
* Sets this Operation's externalDocs property to the given object.
*
* @param externalDocs
* additional external documentation for this operation
**/
void setExternalDocs(ExternalDocumentation externalDocs);
/**
* Sets this Operation's externalDocs property to the given object.
*
* @param externalDocs
* additional external documentation for this operation
* @return the current Operation object
**/
default Operation externalDocs(ExternalDocumentation externalDocs) {
setExternalDocs(externalDocs);
return this;
}
/**
* Returns the operationId property from an Operation instance.
*
* @return unique string used to identify the operation
**/
String getOperationId();
/**
* Sets this Operation's operationId property to the given string.
*
* @param operationId
* unique string used to identify the operation
**/
void setOperationId(String operationId);
/**
* Sets this Operation's operationId property to the given string.
*
* @param operationId
* unique string used to identify the operation
* @return the current Operation object
**/
default Operation operationId(String operationId) {
setOperationId(operationId);
return this;
}
/**
* Returns the parameters property from an Operation instance.
*
* @return a copy List (potentially immutable) of parameters that are applicable for this operation
**/
List getParameters();
/**
* Sets this Operation's parameters property to the given parameter list.
*
* @param parameters
* a list of parameters that are applicable for this operation
**/
void setParameters(List parameters);
/**
* Sets this Operation's parameters property to the given parameter list.
*
* @param parameters
* a list of parameters that are applicable for this operation
* @return the current Operation object
**/
default Operation parameters(List parameters) {
setParameters(parameters);
return this;
}
/**
* Adds the given parameter item to this Operation's list of parameters.
*
* @param parameter
* a parameter that is applicable for this operation
* @return the current Operation object
**/
Operation addParameter(Parameter parameter);
/**
* Removes the given parameter item to this Operation's list of parameters.
*
* @param parameter
* a parameter that is applicable for this operation
**/
void removeParameter(Parameter parameter);
/**
* Returns the requestBody property from an Operation instance.
*
* @return the request body applicable for this operation
**/
RequestBody getRequestBody();
/**
* Sets this Operation's requestBody property to the given object.
*
* @param requestBody
* the request body applicable for this operation
**/
void setRequestBody(RequestBody requestBody);
/**
* Sets this Operation's requestBody property to the given object.
*
* @param requestBody
* the request body applicable for this operation
* @return the current Operation object
**/
default Operation requestBody(RequestBody requestBody) {
setRequestBody(requestBody);
return this;
}
/**
* Returns the responses property from an Operation instance.
*
* @return collection of possible responses from executing this operation
**/
APIResponses getResponses();
/**
* Sets this Operation's responses property to the given responses.
*
* @param responses
* collection of possible responses from executing this operation
**/
void setResponses(APIResponses responses);
/**
* Sets this Operation's responses property to the given responses.
*
* @param responses
* collection of possible responses from executing this operation
* @return the current Operation object
**/
default Operation responses(APIResponses responses) {
setResponses(responses);
return this;
}
/**
* Returns the callbacks property from an Operation instance.
*
* @return a copy Map (potentially immutable) of possible out-of-band callbacks related to the operation
**/
Map getCallbacks();
/**
* Sets this Operation's callbacks property to the given map.
*
* @param callbacks
* map of possible out-of-band callbacks related to the operation. The key value must be the correct
* format for this field.
**/
void setCallbacks(Map callbacks);
/**
* Sets this Operation's callbacks property to the given map.
*
* @param callbacks
* map of possible out-of-band callbacks related to the operation. The key value must be the correct
* format for this field.
* @return the current Operation object
**/
default Operation callbacks(Map callbacks) {
setCallbacks(callbacks);
return this;
}
/**
* Adds the given callback item to this Operation's map of callbacks.
*
* @param key
* a key conforming to the format required for this object
* @param callback
* a callback that is applicable for this operation. null values will be rejected (implementation will
* throw an exception) or ignored.
* @return the current Operation object
**/
Operation addCallback(String key, Callback callback);
/**
* Removes the given callback item to this Operation's map of callbacks.
*
* @param key
* a key conforming to the format required for this object
**/
void removeCallback(String key);
/**
* Returns the deprecated property from an Operation instance.
*
* @return declaration whether this operation is deprecated
**/
Boolean getDeprecated();
/**
* Sets this Operation's deprecated property to the given value.
*
* @param deprecated
* declaration whether this operation is deprecated
**/
void setDeprecated(Boolean deprecated);
/**
* Sets this Operation's deprecated property to the given value.
*
* @param deprecated
* declaration whether this operation is deprecated
* @return the current Operation object
**/
default Operation deprecated(Boolean deprecated) {
setDeprecated(deprecated);
return this;
}
/**
* Returns the security property from an Operation instance.
*
* @return a copy List (potentially immutable) of which security mechanisms can be used for this operation
**/
List getSecurity();
/**
* Sets this Operation's security property to the given list.
*
* @param security
* list of which security mechanisms can be used for this operation
**/
void setSecurity(List security);
/**
* Sets this Operation's security property to the given list.
*
* @param security
* list of which security mechanisms can be used for this operation
* @return the current Operation object
**/
default Operation security(List security) {
setSecurity(security);
return this;
}
/**
* Adds the given security requirement item to this Operation's list of security mechanisms.
*
* @param securityRequirement
* security mechanism which can be used for this operation
* @return the current Operation object
**/
Operation addSecurityRequirement(SecurityRequirement securityRequirement);
/**
* Removes the given security requirement item to this Operation's list of security mechanisms.
*
* @param securityRequirement
* security mechanism which can be used for this operation
**/
void removeSecurityRequirement(SecurityRequirement securityRequirement);
/**
* Returns the servers property from an Operation instance.
*
* @return a copy List (potentially immutable) of servers to service this operation
**/
List getServers();
/**
* Sets this Operation's servers property to the given list.
*
* @param servers
* list of servers to service this operation
**/
void setServers(List servers);
/**
* Sets this Operation's servers property to the given list.
*
* @param servers
* list of servers to service this operation
* @return the current Operation object
**/
default Operation servers(List servers) {
setServers(servers);
return this;
}
/**
* Adds the given server to this Operation's list of servers.
*
* @param server
* server which can service this operation
* @return the current Operation object
**/
Operation addServer(Server server);
/**
* Removes the given server to this Operation's list of servers.
*
* @param server
* server which can service this operation
**/
void removeServer(Server server);
}