--- /dev/null
+/*-
+ * ========================LICENSE_START=================================
+ * O-RAN-SC
+ * %%
+ * Copyright (C) 2019 Nordix Foundation
+ * %%
+ * 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.
+ * ========================LICENSE_END===================================
+ */
+
+package org.oransc.policyagent;
+
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import springfox.documentation.builders.PathSelectors;
+import springfox.documentation.builders.RequestHandlerSelectors;
+import springfox.documentation.spi.DocumentationType;
+import springfox.documentation.spring.web.plugins.Docket;
+import springfox.documentation.swagger2.annotations.EnableSwagger2;
+
+/**
+ * Swagger configuration class that uses swagger2 documentation type and scans all the controllers
+ * under org.oransc.policyagent.controllers package. To access the swagger gui go to
+ * http://ip:port/swagger-ui.html
+ *
+ */
+@Configuration
+@EnableSwagger2
+public class SwaggerConfig {
+ @Bean
+ public Docket api() {
+ return new Docket(DocumentationType.SWAGGER_2).select()
+ .apis(RequestHandlerSelectors.basePackage("org.oransc.policyagent.controllers"))
+ .paths(PathSelectors.any()).build();
+ }
+}
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
-
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import io.swagger.annotations.ApiResponse;
+import io.swagger.annotations.ApiResponses;
import java.util.Collection;
import java.util.Vector;
import org.springframework.web.bind.annotation.RestController;
@RestController
+@Api(value = "Policy Management API")
public class PolicyController {
private final ApplicationConfig appConfig;
}
@GetMapping("/policy_types")
+ @ApiOperation(value = "Returns all the policy types")
+ @ApiResponses(
+ value = {
+ @ApiResponse(code = 200, message = "Policy Types found")
+ })
public ResponseEntity<String> getPolicyTypes() {
Collection<PolicyType> types = this.policyTypes.getAll();
}
@GetMapping("/policy")
+ @ApiOperation(value = "Returns the policy")
+ @ApiResponses(
+ value = {
+ @ApiResponse(code = 200, message = "Policy found"),
+ @ApiResponse(code = 204, message = "Policy is not found")
+ })
public ResponseEntity<String> getPolicy( //
@RequestParam(name = "instance", required = true) String instance) {
try {
}
@DeleteMapping("/policy")
- public ResponseEntity<String> deletePolicy( //
+ @ApiOperation(value = "Deletes the policy")
+ @ApiResponses(
+ value = {
+ @ApiResponse(code = 204, message = "Policy deleted")
+ })
+ public ResponseEntity<Void> deletePolicy( //
@RequestParam(name = "instance", required = true) String instance) {
Policy p = policies.removeId(instance);
- return new ResponseEntity<String>("OK", HttpStatus.OK);
+ return new ResponseEntity<>(HttpStatus.NO_CONTENT);
}
@GetMapping("/policies")
+ @ApiOperation(value = "Returns the policies")
+ @ApiResponses(
+ value = {
+ @ApiResponse(code = 200, message = "Polcies found")
+ })
public ResponseEntity<String> getPolicies( //
@RequestParam(name = "type", required = false) String type, //
@RequestParam(name = "ric", required = false) String ric, //
}
@PutMapping(path = "/policy")
+ @ApiOperation(value = "Create the policy")
+ @ApiResponses(
+ value = {
+ @ApiResponse(code = 201, message = "Policy created")
+ })
public ResponseEntity<String> putPolicy( //
@RequestParam(name = "type", required = true) String type, //
@RequestParam(name = "instance", required = true) String instanceId, //
.lastModified(getTimeStampUTC()) //
.build();
policies.put(policy);
- return new ResponseEntity<String>(HttpStatus.OK);
+ return new ResponseEntity<String>(HttpStatus.CREATED);
} catch (ServiceException e) {
return new ResponseEntity<String>(e.getMessage(), HttpStatus.NOT_FOUND);
}