package it.digione.dg1cloud.service;
|
|
import java.io.File;
|
import java.io.IOException;
|
import java.util.List;
|
|
import org.apache.commons.io.FileUtils;
|
import org.slf4j.Logger;
|
import org.slf4j.LoggerFactory;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
|
import it.digione.dg1cloud.config.AppConfig;
|
import it.digione.dg1cloud.model.RegDocument;
|
import it.digione.dg1cloud.repository.RegDocumentRepository;
|
|
@Service("cleanerService")
|
public class CleanerService {
|
|
private static final Logger logger = LoggerFactory.getLogger(CleanerService.class);
|
|
@Autowired private Utils utils;
|
@Autowired private AppConfig appConfig;
|
@Autowired private RegDocumentRepository regDocumentRepository;
|
|
public void cleanExpiredStoredFiles() {
|
|
List<RegDocument> regDocuments = regDocumentRepository.findAllRegDocumentExpired();
|
logger.debug("Trovati {} documenti da cancellare", regDocuments.size());
|
|
for ( RegDocument regDocument : regDocuments ) {
|
logger.debug("Rimozione file {}", regDocument.getFilePath());
|
File cloudFile = new File( regDocument.getFilePath() );
|
if (cloudFile.exists() == true ) {
|
FileUtils.deleteQuietly(cloudFile);
|
} else {
|
logger.debug("File gia' rimosso. Procedo alla rimozione del record");
|
}
|
logger.debug("Rimozione record");
|
regDocumentRepository.delete(regDocument);
|
logger.debug("Record rimosso");
|
|
try {
|
utils.deleteDir(cloudFile.getParentFile());
|
} catch (Exception e) {
|
logger.warn("ERRORE: Problemi nella rimozione della directory", e);
|
}
|
}
|
}
|
|
public void cleanEmptyStorageFolder() {
|
String baseStoragePath = appConfig.getRepositoryBaseStoragePath();
|
logger.debug("Avvio esplorazione ricorsiva directory vuote da eliminare partendo da {}", baseStoragePath);
|
try {
|
utils.deleteEmptyDirectoriesRecursive(new File(baseStoragePath));
|
} catch (IOException e) {
|
logger.error("Errore nell'esplorazione delle sotto directory", e);
|
}
|
}
|
}
|