Search in sources :

Example 1 with LogResponse

use of org.opentosca.toscana.api.model.LogResponse in project TOSCAna by StuPro-TOSCAna.

the class CsarController method getLogs.

/**
 *     Returns the logs from a given start index to the current end of the logger file. If the start index is higher then
 *     the current end index, a empty list is returned! The start parameter is a URL encoded parameter
 *     (<code>?start=0</code>)
 *     <p>
 *     Accessed with http call <code>GET /csars/{csar}/transformations/{platform}/logs</code>
 *     <table summary="">
 *     <tr>
 *     <td>HTTP-Code</td>
 *     <td>Mime-Type</td>
 *     <td>Description (Returned if)</td>
 *     </tr>
 *     <tr>
 *     <td>200</td>
 *     <td>application/hal+json</td>
 *     <td>Returns a Json object containing the desired part of the logger for the transformation</td>
 *     </tr>
 *     <tr>
 *     <td>404</td>
 *     <td>application/json</td>
 *     <td>Returns a error message if the csar is not found or if the csar does not have a transformation for the given
 *     name (see returned error message for details)</td>
 *     </tr>
 *     </table>
 */
@RequestMapping(path = "/{name}/logs", method = RequestMethod.GET, produces = "application/hal+json")
@ApiOperation(value = "Get the logs of a csar", tags = { "csars" }, notes = "Returns the logs for a csar, starting at a specific position. from the given start index all " + "following log lines get returned. If the start index is larger than the current last log index the operation " + "will return a empty list.")
@ApiResponses({ @ApiResponse(code = 200, message = "The operation was executed successfully", response = LogResponse.class), @ApiResponse(code = 400, message = "The given start value is less than zero", response = RestErrorResponse.class), @ApiResponse(code = 404, message = "There is no CSAR for the given identifier", response = RestErrorResponse.class) })
public ResponseEntity<LogResponse> getLogs(@ApiParam(value = "The unique identifier for the CSAR", required = true, example = "test") @PathVariable(name = "name") String csarId, @ApiParam(value = "The index of the first log entry you want (0 returns the whole log)", required = true, example = "0") @RequestParam(name = "start", required = false, defaultValue = "0") Long start) {
    if (start < 0) {
        throw new IndexOutOfBoundsException("the start index has to be at least 0");
    }
    Csar csar = getCsarForName(csarId);
    Log log = csar.getLog();
    List<LogEntry> entries = log.getLogEntries(Math.toIntExact(start));
    return ResponseEntity.ok().body(new LogResponse(start, entries.size() == 0 ? start : start + entries.size() - 1, entries, csarId));
}
Also used : Csar(org.opentosca.toscana.core.csar.Csar) LogResponse(org.opentosca.toscana.api.model.LogResponse) Log(org.opentosca.toscana.core.transformation.logging.Log) LogEntry(org.opentosca.toscana.core.transformation.logging.LogEntry) ApiOperation(io.swagger.annotations.ApiOperation) ApiResponses(io.swagger.annotations.ApiResponses) RequestMapping(org.springframework.web.bind.annotation.RequestMapping)

Example 2 with LogResponse

use of org.opentosca.toscana.api.model.LogResponse in project TOSCAna by StuPro-TOSCAna.

the class TransformationController method getTransformationLogs.

/**
 *     Returns the logs from a given start index to the current end of the logger file. If the start index is higher then
 *     the current end index, a empty list is returned! The start parameter is a URL encoded parameter
 *     (<code>?start=0</code>)
 *     <p>
 *     Accessed with http call <code>GET /csars/{csar}/transformations/{platform}/logs</code>
 *     <table summary="">
 *     <tr>
 *     <td>HTTP-Code</td>
 *     <td>Mime-Type</td>
 *     <td>Description (Returned if)</td>
 *     </tr>
 *     <tr>
 *     <td>200</td>
 *     <td>application/hal+json</td>
 *     <td>Returns a Json object containing the desired part of the logger for the transformation</td>
 *     </tr>
 *     <tr>
 *     <td>404</td>
 *     <td>application/json</td>
 *     <td>Returns a error message if the csar is not found or if the csar does not have a transformation for the given
 *     name (see returned error message for details)</td>
 *     </tr>
 *     </table>
 */
@RequestMapping(path = "/{platform}/logs", method = RequestMethod.GET, produces = "application/hal+json")
@ApiOperation(value = "Get the logs for a Transformation", tags = { "transformations" }, notes = "Returns the logs for a transformation, starting at a specific position. from the given start index all " + "following log lines get returned. If the start index is larger than the current last log index the operation " + "will return a empty list.")
@ApiResponses({ @ApiResponse(code = 200, message = "The operation was executed successfully", response = LogResponse.class), @ApiResponse(code = 400, message = "The given start value is less than zero", response = RestErrorResponse.class), @ApiResponse(code = 404, message = "There is no CSAR for the given identifier or the CSAR does not have " + "a Transformation for the specified platform.", response = RestErrorResponse.class) })
public ResponseEntity<LogResponse> getTransformationLogs(@ApiParam(value = "The unique identifier for the CSAR", required = true, example = "test") @PathVariable(name = "csarId") String csarId, @ApiParam(value = "The identifier for the platform", required = true, example = "kubernetes") @PathVariable(name = "platform") String platformId, @ApiParam(value = "The index of the first log entry you want (0 returns the whole log)", required = true, example = "0") @RequestParam(name = "start", required = false, defaultValue = "0") Long start) {
    if (start < 0) {
        throw new IndexOutOfBoundsException("the start index has to be at least 0");
    }
    Csar csar = findByCsarId(csarId);
    Transformation transformation = findTransformationByPlatform(csar, platformId);
    Log log = transformation.getLog();
    List<LogEntry> entries = log.getLogEntries(Math.toIntExact(start));
    return ResponseEntity.ok().body(new LogResponse(start, // TODO Maybe move this calculation into the LogResponse Class
    entries.size() == 0 ? start : start + entries.size() - 1, entries, platformId, csarId));
}
Also used : Csar(org.opentosca.toscana.core.csar.Csar) Transformation(org.opentosca.toscana.core.transformation.Transformation) LogResponse(org.opentosca.toscana.api.model.LogResponse) Log(org.opentosca.toscana.core.transformation.logging.Log) LogEntry(org.opentosca.toscana.core.transformation.logging.LogEntry) ApiOperation(io.swagger.annotations.ApiOperation) ApiResponses(io.swagger.annotations.ApiResponses) RequestMapping(org.springframework.web.bind.annotation.RequestMapping)

Aggregations

ApiOperation (io.swagger.annotations.ApiOperation)2 ApiResponses (io.swagger.annotations.ApiResponses)2 LogResponse (org.opentosca.toscana.api.model.LogResponse)2 Csar (org.opentosca.toscana.core.csar.Csar)2 Log (org.opentosca.toscana.core.transformation.logging.Log)2 LogEntry (org.opentosca.toscana.core.transformation.logging.LogEntry)2 RequestMapping (org.springframework.web.bind.annotation.RequestMapping)2 Transformation (org.opentosca.toscana.core.transformation.Transformation)1