blob: d1df4df9b538aae871d5ed43eb95fe0c4690944d [file] [log] [blame]
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~ Licensed to the Apache Software Foundation (ASF) under one
~ or more contributor license agreements. See the NOTICE file
~ distributed with this work for additional information
~ regarding copyright ownership. The ASF licenses this file
~ to you under the Apache License, Version 2.0 (the
~ "License"); you may not use this file except in compliance
~ with the License. You may obtain a copy of the License at
~
~ http://www.apache.org/licenses/LICENSE-2.0
~
~ Unless required by applicable law or agreed to in writing,
~ software distributed under the License is distributed on an
~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
~ KIND, either express or implied. See the License for the
~ specific language governing permissions and limitations
~ under the License.
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
package org.apache.sling.scriptingbundle.plugin.processor;
import java.io.IOException;
import java.io.UncheckedIOException;
import java.nio.file.DirectoryStream;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.Collections;
import java.util.LinkedHashSet;
import java.util.Set;
import java.util.stream.Stream;
import org.apache.commons.io.FilenameUtils;
import org.apache.jackrabbit.vault.util.PlatformNameFormat;
import org.apache.sling.api.resource.type.ResourceType;
import org.apache.sling.scriptingbundle.plugin.capability.Capabilities;
import org.apache.sling.scriptingbundle.plugin.capability.ProvidedResourceTypeCapability;
import org.apache.sling.scriptingbundle.plugin.capability.RequiredResourceTypeCapability;
import org.jetbrains.annotations.NotNull;
public class ResourceTypeFolderAnalyser {
private final Logger logger;
private final Path scriptsDirectory;
private final ResourceTypeFolderPredicate resourceTypeFolderPredicate;
private final FileProcessor fileProcessor;
private final boolean inContentPackage;
public ResourceTypeFolderAnalyser(@NotNull Logger logger, @NotNull Path scriptsDirectory, @NotNull FileProcessor fileProcessor,
boolean inContentPackage) {
this.logger = logger;
this.scriptsDirectory = scriptsDirectory;
this.resourceTypeFolderPredicate = new ResourceTypeFolderPredicate(logger, inContentPackage);
this.fileProcessor = fileProcessor;
this.inContentPackage = inContentPackage;
}
public Capabilities getCapabilities(@NotNull Path resourceTypeDirectory) {
Set<ProvidedResourceTypeCapability> providedCapabilities = new LinkedHashSet<>();
Set<RequiredResourceTypeCapability> requiredCapabilities = new LinkedHashSet<>();
if (resourceTypeDirectory.startsWith(scriptsDirectory) && resourceTypeFolderPredicate.test(resourceTypeDirectory)) {
try (DirectoryStream<Path> resourceTypeDirectoryStream = Files.newDirectoryStream(resourceTypeDirectory)) {
Path relativeResourceTypeDirectory = scriptsDirectory.relativize(resourceTypeDirectory);
final ResourceType resourceType =
ResourceType.parseResourceType(
FilenameUtils.normalize(inContentPackage ?
PlatformNameFormat.getRepositoryPath(relativeResourceTypeDirectory.toString()) :
relativeResourceTypeDirectory.toString(),
true
)
);
resourceTypeDirectoryStream.forEach(entry -> {
if (Files.isRegularFile(entry)) {
Path file = entry.getFileName();
if (file != null) {
if (Constants.EXTENDS_FILE.equals(file.toString())) {
fileProcessor.processExtendsFile(resourceType, entry, providedCapabilities, requiredCapabilities);
} else if (Constants.REQUIRES_FILE.equals(file.toString())) {
fileProcessor.processRequiresFile(entry, requiredCapabilities);
} else if (org.apache.jackrabbit.vault.util.Constants.DOT_CONTENT_XML.equals(file.toString())) {
fileProcessor.processVaultFile(entry, resourceType, providedCapabilities, requiredCapabilities);
} else {
fileProcessor.processScriptFile(resourceTypeDirectory, entry, resourceType, providedCapabilities, inContentPackage);
}
}
} else if (Files.isDirectory(entry) && !resourceTypeFolderPredicate.test(entry)) {
try (Stream<Path> selectorFilesStream = Files.walk(entry).filter(Files::isRegularFile).filter(file -> {
Path fileParent = file.getParent();
while (!resourceTypeDirectory.equals(fileParent)) {
if (resourceTypeFolderPredicate.test(fileParent)) {
return false;
}
fileParent = fileParent.getParent();
}
return true;
})) {
selectorFilesStream.forEach(
file -> fileProcessor.processScriptFile(resourceTypeDirectory, file, resourceType,
providedCapabilities, inContentPackage)
);
} catch (IOException e) {
logger.error(String.format("Unable to scan folder %s.", entry.toString()), e);
}
}
});
} catch (IOException e) {
throw new UncheckedIOException(e);
}
}
return new Capabilities(providedCapabilities, Collections.emptySet(), requiredCapabilities);
}
}