2 * NOTE: This class is auto generated by the swagger code generator program ({{{generatorVersion}}}).
3 * https://github.com/swagger-api/swagger-codegen
4 * Do not edit the class manually.
8 {{#imports}}import {{import}};
11 import com.fasterxml.jackson.databind.ObjectMapper;
13 import io.swagger.annotations.*;
15 import org.slf4j.Logger;
16 import org.slf4j.LoggerFactory;
17 import org.springframework.http.HttpStatus;
19 import org.springframework.http.ResponseEntity;
20 {{#useBeanValidation}}
21 import org.springframework.validation.annotation.Validated;
22 {{/useBeanValidation}}
23 import org.springframework.web.bind.annotation.PathVariable;
24 import org.springframework.web.bind.annotation.RequestBody;
25 import org.springframework.web.bind.annotation.RequestHeader;
26 import org.springframework.web.bind.annotation.RequestMapping;
27 import org.springframework.web.bind.annotation.RequestMethod;
28 import org.springframework.web.bind.annotation.RequestParam;
29 import org.springframework.web.bind.annotation.RequestPart;
30 import org.springframework.web.multipart.MultipartFile;
31 import org.onap.ccsdk.apps.services.RestException;
34 import javax.servlet.http.HttpServletRequest;
36 {{#useBeanValidation}}
37 import javax.validation.Valid;
38 import javax.validation.constraints.*;
39 {{/useBeanValidation}}
41 import java.io.IOException;
43 import java.util.List;
45 import java.util.Optional;
49 import java.util.Optional;
53 import java.util.concurrent.{{^jdk8}}Callable{{/jdk8}}{{#jdk8}}CompletableFuture{{/jdk8}};
55 {{>generatedAnnotation}}
56 @Api(value = "{{{baseName}}}", description = "the {{{baseName}}} API")
58 public interface {{classname}} {
62 Logger log = LoggerFactory.getLogger({{classname}}.class);
64 default Optional<ObjectMapper> getObjectMapper() {
65 return Optional.empty();
68 default Optional<HttpServletRequest> getRequest() {
69 return Optional.empty();
72 default Optional<String> getAcceptHeader() {
73 return getRequest().map(r -> r.getHeader("Accept"));
77 {{classname}}Delegate getDelegate();
82 @ApiOperation(value = "{{{summary}}}", nickname = "{{{operationId}}}", notes = "{{{notes}}}"{{#returnBaseType}}, response = {{{returnBaseType}}}.class{{/returnBaseType}}{{#returnContainer}}, responseContainer = "{{{returnContainer}}}"{{/returnContainer}}{{#hasAuthMethods}}, authorizations = {
83 {{#authMethods}}@Authorization(value = "{{name}}"{{#isOAuth}}, scopes = {
84 {{#scopes}}@AuthorizationScope(scope = "{{scope}}", description = "{{description}}"){{#hasMore}},
85 {{/hasMore}}{{/scopes}}
86 }{{/isOAuth}}){{#hasMore}},
87 {{/hasMore}}{{/authMethods}}
88 }{{/hasAuthMethods}}, tags={ {{#vendorExtensions.x-tags}}"{{tag}}",{{/vendorExtensions.x-tags}} })
89 @ApiResponses(value = { {{#responses}}
90 @ApiResponse(code = {{{code}}}, message = "{{{message}}}"{{#baseType}}, response = {{{baseType}}}.class{{/baseType}}{{#containerType}}, responseContainer = "{{{containerType}}}"{{/containerType}}){{#hasMore}},{{/hasMore}}{{/responses}} })
98 @RequestMapping(value = "{{{path}}}",{{#singleContentTypes}}
99 produces = "{{{vendorExtensions.x-accepts}}}",
100 consumes = "{{{vendorExtensions.x-contentType}}}",{{/singleContentTypes}}{{^singleContentTypes}}{{#hasProduces}}
101 produces = { {{#produces}}"{{{mediaType}}}"{{#hasMore}}, {{/hasMore}}{{/produces}} }, {{/hasProduces}}{{#hasConsumes}}
102 consumes = { {{#consumes}}"{{{mediaType}}}"{{#hasMore}}, {{/hasMore}}{{/consumes}} },{{/hasConsumes}}{{/singleContentTypes}}
103 method = RequestMethod.{{httpMethod}})
104 {{#jdk8}}default {{/jdk8}}{{#responseWrapper}}{{.}}<{{/responseWrapper}}ResponseEntity<{{>returnTypes}}>{{#responseWrapper}}>{{/responseWrapper}} {{#delegate-method}}_{{/delegate-method}}{{operationId}}({{#allParams}}{{>queryParams}}{{>pathParams}}{{>headerParams}}{{>bodyParams}}{{>formParams}}{{#hasMore}},{{/hasMore}}{{/allParams}}){{^jdk8}};{{/jdk8}}{{#jdk8}} throws RestException {
106 return {{operationId}}({{#allParams}}{{paramName}}{{#hasMore}}, {{/hasMore}}{{/allParams}});
109 // Override this method
110 default {{#responseWrapper}}{{.}}<{{/responseWrapper}}ResponseEntity<{{>returnTypes}}>{{#responseWrapper}}>{{/responseWrapper}} {{operationId}}({{#allParams}}{{^isFile}}{{{dataType}}}{{/isFile}}{{#isFile}}MultipartFile{{/isFile}} {{paramName}}{{#hasMore}},{{/hasMore}}{{/allParams}}) throws RestException {
113 if(getObjectMapper().isPresent() && getAcceptHeader().isPresent()) {
115 if (getAcceptHeader().get().contains("{{{contentType}}}")) {
117 return {{#async}}CompletableFuture.completedFuture({{/async}}new ResponseEntity<>(getObjectMapper().get().readValue("{{#lambdaRemoveLineBreak}}{{#lambdaEscapeDoubleQuote}}{{{example}}}{{/lambdaEscapeDoubleQuote}}{{/lambdaRemoveLineBreak}}", {{>exampleReturnTypes}}.class), HttpStatus.NOT_IMPLEMENTED){{#async}}){{/async}};
118 } catch (IOException e) {
119 log.error("Couldn't serialize response for content type {{{contentType}}}", e);
120 return {{#async}}CompletableFuture.completedFuture({{/async}}new ResponseEntity<>(HttpStatus.INTERNAL_SERVER_ERROR){{#async}}){{/async}};
125 log.warn("ObjectMapper or HttpServletRequest not configured in default {{classname}} interface so no example is generated");
127 return {{#async}}CompletableFuture.completedFuture({{/async}}new ResponseEntity<>(HttpStatus.NOT_IMPLEMENTED){{#async}}){{/async}};
130 return getDelegate().{{operationId}}({{#allParams}}{{paramName}}{{#hasMore}}, {{/hasMore}}{{/allParams}});