Search in sources :

Example 1 with IPurgeService

use of org.pentaho.di.ui.repository.pur.services.IPurgeService in project pentaho-kettle by pentaho.

the class PurgeResource method doDeleteRevisions.

/**
 * Provides a utility for purging files and/or revision history for the DI server.
 *
 * <p>
 * <b>Example Request:</b><br>
 * POST /pur-repository-plugin/api/purge/path:to:file/purge
 * </p>
 *
 * @param pathId
 *          Colon separated path for the repository file. Processing of files will occur under this path. Exception:
 *          If purgeSharedObject=true other files may be affected as well.
 * @param purgeFiles
 *          If true, files will be purged completely. This options erases files and all history. This effectively
 *          disables all parameters effecting revisions since all revisions will be deleted unconditionally.
 * @param purgeRevisions
 *          If true, all revisions to the targeted files will be purged. The current state of the file will be
 *          retained.
 * @param purgeSharedObjects
 *          If true, Shared objects will also be targeted by the purge operation. This does not replace the pathId and
 *          fileFilter processing, but rather, is in addition to that processing. If it is desired to purge shared
 *          objects only without effecting other files, then set the pathId to a single space character. Some examples
 *          of shared objects database connections, Slave Servers, Cluster Schemas, and partition Schemas.
 * @param versionCount
 *          If present, the number of historical revisions to keep. If there are more revisions for a file than
 *          versionCount, the older ones will be removed.
 * @param purgeBeforeDate
 *          If set, remove all version history created prior to this date.
 * @param fileFilter
 *          The file filter to be applied when determining what files are affected by the purge. This filter is used
 *          by the <code>tree</code> endpoint to determine what files to return. The fileFilter is a list of allowed
 *          names of files separated by the pipe (|) character. Each file name in the filter may be a full name or a
 *          partial name with one or more wildcard characters ("*"). (eg: *.ktr|*.kjb returns all files with a ktr or
 *          kjb extension).
 * @param logLevelName
 *          The standard name for the log level (ie: INFO, DEBUG)
 * @return A text file containing a log of the service execution.
 */
@POST
@Path("{pathId : .+}/purge")
@StatusCodes({ @ResponseCode(code = 200, condition = "Successfully purged specified target"), @ResponseCode(code = 500, condition = "Something failed when attempting to purge "), @ResponseCode(code = 404, condition = "Invalid path") })
@Consumes(MediaType.MULTIPART_FORM_DATA)
@Produces({ WILDCARD })
public Response doDeleteRevisions(@PathParam("pathId") String pathId, @DefaultValue("false") @FormDataParam("purgeFiles") boolean purgeFiles, @DefaultValue("false") @FormDataParam("purgeRevisions") boolean purgeRevisions, @DefaultValue("false") @FormDataParam("purgeSharedObjects") boolean purgeSharedObjects, @DefaultValue("-1") @FormDataParam("versionCount") int versionCount, @FormDataParam("purgeBeforeDate") Date purgeBeforeDate, @DefaultValue("*") @FormDataParam("fileFilter") String fileFilter, @DefaultValue("INFO") @FormDataParam("logLevel") String logLevelName) {
    // A version count of 0 is illegal.
    if (versionCount == 0) {
        return Response.serverError().build();
    }
    if (purgeRevisions && (versionCount > 0 || purgeBeforeDate != null)) {
        purgeRevisions = false;
    }
    IPurgeService purgeService = new UnifiedRepositoryPurgeService(this.repository);
    Level logLevel = Level.toLevel(logLevelName);
    PurgeUtilitySpecification purgeSpecification = new PurgeUtilitySpecification();
    purgeSpecification.setPath(idToPath(pathId));
    purgeSpecification.setPurgeFiles(purgeFiles);
    purgeSpecification.setPurgeRevisions(purgeRevisions);
    purgeSpecification.setSharedObjects(purgeSharedObjects);
    purgeSpecification.setVersionCount(versionCount);
    purgeSpecification.setBeforeDate(purgeBeforeDate);
    purgeSpecification.setFileFilter(fileFilter);
    purgeSpecification.setLogLevel(logLevel);
    // Initialize the logger
    ByteArrayOutputStream purgeUtilityStream = new ByteArrayOutputStream();
    PurgeUtilityLogger.createNewInstance(purgeUtilityStream, purgeSpecification.getPath(), logLevel);
    try {
        purgeService.doDeleteRevisions(purgeSpecification);
    } catch (Exception e) {
        PurgeUtilityLogger.getPurgeUtilityLogger().error(e);
        return Response.ok(encodeOutput(purgeUtilityStream), MediaType.TEXT_HTML).build();
    }
    return Response.ok(encodeOutput(purgeUtilityStream), MediaType.TEXT_HTML).build();
}
Also used : IPurgeService(org.pentaho.di.ui.repository.pur.services.IPurgeService) Level(org.apache.log4j.Level) ByteArrayOutputStream(java.io.ByteArrayOutputStream) UnsupportedEncodingException(java.io.UnsupportedEncodingException) Path(javax.ws.rs.Path) POST(javax.ws.rs.POST) Consumes(javax.ws.rs.Consumes) Produces(javax.ws.rs.Produces) StatusCodes(org.codehaus.enunciate.jaxrs.StatusCodes)

Aggregations

ByteArrayOutputStream (java.io.ByteArrayOutputStream)1 UnsupportedEncodingException (java.io.UnsupportedEncodingException)1 Consumes (javax.ws.rs.Consumes)1 POST (javax.ws.rs.POST)1 Path (javax.ws.rs.Path)1 Produces (javax.ws.rs.Produces)1 Level (org.apache.log4j.Level)1 StatusCodes (org.codehaus.enunciate.jaxrs.StatusCodes)1 IPurgeService (org.pentaho.di.ui.repository.pur.services.IPurgeService)1