From 452e209605a85e508b5e5a41c4b6a7534072d328 Mon Sep 17 00:00:00 2001 From: Mirjan Hoffmann Date: Mon, 12 Oct 2020 11:19:18 +0200 Subject: [PATCH] Fixed access to nullable ContentReader --- .../services/AntivirusServiceImpl.java | 27 ++++++++++++------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/alfviral/src/main/java/com/fegor/alfresco/services/AntivirusServiceImpl.java b/alfviral/src/main/java/com/fegor/alfresco/services/AntivirusServiceImpl.java index 456ae2b..2122bb6 100644 --- a/alfviral/src/main/java/com/fegor/alfresco/services/AntivirusServiceImpl.java +++ b/alfviral/src/main/java/com/fegor/alfresco/services/AntivirusServiceImpl.java @@ -144,11 +144,7 @@ public void scanFile(NodeRef nodeRef) throws InvalidNodeRefException { if (nodeService.exists(nodeRef)) { contentReader = contentService.getReader(nodeRef, ContentModel.PROP_CONTENT); - if ((contentReader != null) - && (fileExceptions.indexOf(contentReader.getMimetype()) == -1 - && (fileOnlyOrExceptions.toLowerCase()).equals(FILE_EXCEPTIONS)) - || (fileOnly.indexOf(contentReader.getMimetype()) != -1 - && (fileOnlyOrExceptions.toLowerCase()).equals(FILE_ONLY))) { + if (shouldScan(contentReader)) { String contentUrl = contentReader.getContentUrl(); String contentPath = contentUrl.replaceFirst("store:/", this.store); @@ -249,13 +245,24 @@ else if (mode.toUpperCase().equals(VirusScanMode.ScanModeICap)) { logger.debug("[File: " + contentReader.getContentUrl() + " is clean"); } } + } + } - else if ((!(fileOnlyOrExceptions.toLowerCase()).equals(FILE_ONLY)) - || (!(fileOnlyOrExceptions.toLowerCase()).equals(FILE_EXCEPTIONS))) { - logger.error("Property alfviral.file.only_or_exceptions not is '" + FILE_ONLY + "' or '" - + FILE_EXCEPTIONS + "'"); - } + private boolean shouldScan(final ContentReader contentReader) { + if ((!(fileOnlyOrExceptions.toLowerCase()).equals(FILE_ONLY)) + && (!(fileOnlyOrExceptions.toLowerCase()).equals(FILE_EXCEPTIONS))) { + logger.error("Property alfviral.file.only_or_exceptions not is '" + FILE_ONLY + "' or '" + FILE_EXCEPTIONS + + "'"); + return false; + } + if (contentReader != null) { + final boolean fileExceptionsMatches = fileExceptions.indexOf(contentReader.getMimetype()) == -1 + && (fileOnlyOrExceptions.toLowerCase()).equals(FILE_EXCEPTIONS); + final boolean fileOnlyMatches = fileOnly.indexOf(contentReader.getMimetype()) != -1 + && (fileOnlyOrExceptions.toLowerCase()).equals(FILE_ONLY); + return fileExceptionsMatches || fileOnlyMatches; } + return false; } /**