X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=dmaap-adaptor-java%2Fsrc%2Fmain%2Fjava%2Forg%2Foran%2Fdmaapadapter%2Fcontrollers%2FProducerCallbacksController.java;h=94f9f8db9ea8788732bdf314e88865fc53f58778;hb=09e21f39a3ffcfc2063110bcad028014b0056398;hp=ca7c96cda83b20b5adb5b53b8e6aed142a5a22a6;hpb=9bdb9a9a925ffc15c7c55998975662c0529abefb;p=nonrtric.git diff --git a/dmaap-adaptor-java/src/main/java/org/oran/dmaapadapter/controllers/ProducerCallbacksController.java b/dmaap-adaptor-java/src/main/java/org/oran/dmaapadapter/controllers/ProducerCallbacksController.java index ca7c96cd..94f9f8db 100644 --- a/dmaap-adaptor-java/src/main/java/org/oran/dmaapadapter/controllers/ProducerCallbacksController.java +++ b/dmaap-adaptor-java/src/main/java/org/oran/dmaapadapter/controllers/ProducerCallbacksController.java @@ -34,6 +34,7 @@ import io.swagger.v3.oas.annotations.tags.Tag; import java.util.ArrayList; import java.util.Collection; +import org.oran.dmaapadapter.exceptions.ServiceException; import org.oran.dmaapadapter.r1.ProducerJobInfo; import org.oran.dmaapadapter.repository.InfoTypes; import org.oran.dmaapadapter.repository.Job; @@ -58,8 +59,8 @@ public class ProducerCallbacksController { public static final String API_NAME = "Producer job control API"; public static final String API_DESCRIPTION = ""; - public static final String JOB_URL = "/dmaap_dataproducer/info_job"; - public static final String SUPERVISION_URL = "/dmaap_dataproducer/health_check"; + public static final String JOB_URL = "/generic_dataproducer/info_job"; + public static final String SUPERVISION_URL = "/generic_dataproducer/health_check"; private static Gson gson = new GsonBuilder().create(); private final Jobs jobs; private final InfoTypes types; @@ -77,22 +78,31 @@ public class ProducerCallbacksController { content = @Content(schema = @Schema(implementation = VoidResponse.class))), // @ApiResponse(responseCode = "404", description = "Information type is not found", // content = @Content(schema = @Schema(implementation = ErrorResponse.ErrorInfo.class))), // + @ApiResponse(responseCode = "400", description = "Other error in the request", // + content = @Content(schema = @Schema(implementation = ErrorResponse.ErrorInfo.class))) // }) public ResponseEntity jobCreatedCallback( // @RequestBody String body) { try { ProducerJobInfo request = gson.fromJson(body, ProducerJobInfo.class); - - logger.info("Job started callback {}", request.id); - Job job = new Job(request.id, request.targetUri, types.getType(request.typeId), request.owner, - request.lastUpdated); - this.jobs.put(job); + logger.debug("Job started callback {}", request.id); + this.jobs.addJob(request.id, request.targetUri, types.getType(request.typeId), request.owner, + request.lastUpdated, toJobParameters(request.jobData)); return new ResponseEntity<>(HttpStatus.OK); + } catch (ServiceException e) { + logger.warn("jobCreatedCallback failed: {}", e.getMessage()); + return ErrorResponse.create(e, e.getHttpStatus()); } catch (Exception e) { - return ErrorResponse.create(e, HttpStatus.NOT_FOUND); + logger.warn("jobCreatedCallback failed: {}", e.getMessage()); + return ErrorResponse.create(e, HttpStatus.BAD_REQUEST); } } + private Job.Parameters toJobParameters(Object jobData) { + String json = gson.toJson(jobData); + return gson.fromJson(json, Job.Parameters.class); + } + @GetMapping(path = JOB_URL, produces = MediaType.APPLICATION_JSON_VALUE) @Operation(summary = "Get all jobs", description = "Returns all info jobs, can be used for trouble shooting") @ApiResponse(responseCode = "200", // @@ -118,7 +128,7 @@ public class ProducerCallbacksController { public ResponseEntity jobDeletedCallback( // @PathVariable("infoJobId") String infoJobId) { - logger.info("Job deleted callback {}", infoJobId); + logger.debug("Job deleted callback {}", infoJobId); this.jobs.remove(infoJobId); return new ResponseEntity<>(HttpStatus.OK); }