X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Fmain%2Fjava%2Forg%2Foransc%2Fpolicyagent%2Fcontrollers%2FRicRepositoryController.java;h=a96766d308f848620a26f4685d11a87df7e444ad;hb=refs%2Fchanges%2F12%2F2712%2F3;hp=a56678167fe120e96cc3d3ddb5d2712d2d91f2f0;hpb=f26d17f375a8ab4d521549543d4fcc36bdc98865;p=nonrtric.git diff --git a/policy-agent/src/main/java/org/oransc/policyagent/controllers/RicRepositoryController.java b/policy-agent/src/main/java/org/oransc/policyagent/controllers/RicRepositoryController.java index a5667816..a96766d3 100644 --- a/policy-agent/src/main/java/org/oransc/policyagent/controllers/RicRepositoryController.java +++ b/policy-agent/src/main/java/org/oransc/policyagent/controllers/RicRepositoryController.java @@ -28,10 +28,11 @@ import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiResponse; import io.swagger.annotations.ApiResponses; +import java.util.ArrayList; +import java.util.List; import java.util.Optional; -import java.util.Vector; -import org.oransc.policyagent.configuration.ApplicationConfig; +import org.oransc.policyagent.repository.PolicyTypes; import org.oransc.policyagent.repository.Ric; import org.oransc.policyagent.repository.Rics; import org.springframework.beans.factory.annotation.Autowired; @@ -42,22 +43,21 @@ import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @RestController -@Api(value = "RIC Management API") +@Api(tags = "RIC Repository") public class RicRepositoryController { @Autowired private Rics rics; + @Autowired + PolicyTypes types; + private static Gson gson = new GsonBuilder() // .serializeNulls() // .create(); // - @Autowired - RicRepositoryController(ApplicationConfig appConfig) { - } - /** - * Example: http://localhost:8080/rics?managedElementId=kista_1 + * Example: http://localhost:8081/rics?managedElementId=kista_1 */ @GetMapping("/ric") @ApiOperation(value = "Returns the name of a RIC managing one Mananged Element") @@ -79,19 +79,22 @@ public class RicRepositoryController { } /** - * @return a Json array of all RIC data - * Example: http://localhost:8080/ric + * @return a Json array of all RIC data Example: http://localhost:8081/ric */ @GetMapping("/rics") - @ApiOperation(value = "Returns NearRT RIC information") + @ApiOperation(value = "Query NearRT RIC information") @ApiResponses( value = { // - @ApiResponse(code = 200, message = "OK", response = RicInfo.class, responseContainer = "List") // - }) + @ApiResponse(code = 200, message = "OK", response = RicInfo.class, responseContainer = "List"), // + @ApiResponse(code = 404, message = "Policy type is not found", response = String.class)}) public ResponseEntity getRics( @RequestParam(name = "policyType", required = false) String supportingPolicyType) { - Vector result = new Vector<>(); + if ((supportingPolicyType != null) && (this.types.get(supportingPolicyType) == null)) { + return new ResponseEntity<>("Policy type not found", HttpStatus.NOT_FOUND); + } + + List result = new ArrayList<>(); synchronized (rics) { for (Ric ric : rics.getRics()) { if (supportingPolicyType == null || ric.isSupportingType(supportingPolicyType)) {