org.apache.sling.distribution.SimpleDistributionRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aem-sdk-api Show documentation
Show all versions of aem-sdk-api Show documentation
The Adobe Experience Manager SDK
/*
* 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.distribution;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;
import javax.annotation.Nonnull;
import org.osgi.annotation.versioning.ProviderType;
/**
* A {@link SimpleDistributionRequest} is a {@link DistributionRequest} where all paths are either "deep" or "shallow".
*/
@ProviderType
public final class SimpleDistributionRequest implements DistributionRequest {
private final DistributionRequestType requestType;
private final Set deepPaths;
private final Map pathFilters;
private final String[] paths;
/**
* Creates distribution request with "deep" or "shallow" paths.
* @param requestType the request type
* @param isDeep is true
if all paths are "deep" and is false
if all paths are "shallow"
* @param paths the array of paths to be distributed
*/
public SimpleDistributionRequest(DistributionRequestType requestType, boolean isDeep, String... paths) {
this(requestType, paths, isDeep? new HashSet(Arrays.asList(paths)) : new HashSet());
}
/**
* Creates a distribution request with "shallow" paths.
* @param requestType the request type
* @param paths the array of paths to be distributed
*/
public SimpleDistributionRequest(DistributionRequestType requestType, String... paths) {
this(requestType, false, paths);
}
/**
* Creates a distribution request with additional "deep" paths.
* @param requestType the request type
* @param paths the array of paths to be distributed
* @param deepPaths the set of paths that are to be distributed in depth (with all their children)
*/
public SimpleDistributionRequest(DistributionRequestType requestType, String[] paths, Set deepPaths) {
this(requestType, paths, deepPaths, new HashMap());
}
/**
* Creates a distribution request with "deep" paths and filters.
* @param requestType the request type
* @param paths the array of paths to be distributed
* @param deepPaths the set of paths that are to be distributed in depth (with all their children)
* @param pathFilters the filters applicable for each path
*/
public SimpleDistributionRequest(DistributionRequestType requestType, String[] paths, Set deepPaths, Map pathFilters) {
this.requestType = requestType;
this.paths = sanitise(paths);
this.deepPaths = sanitise(deepPaths);
this.pathFilters = pathFilters;
}
/**
* get the {@link DistributionRequestType} associated with this request
*
* @return the type of the request as a {@link DistributionRequestType}
*/
@Nonnull
public DistributionRequestType getRequestType() {
return requestType;
}
/**
* get the paths for this distribution request
*
* @return an array of paths
*/
public String[] getPaths() {
return paths;
}
/**
* Returns whether the a path is covering the entire subtree (deep) or just the specified nodes (shallow)
* @return true
if the path is deep
*/
public boolean isDeep(String path) {
return deepPaths.contains(path);
}
@Nonnull
public String[] getFilters(String path) {
String[] filters = pathFilters.get(path);
return filters != null ? filters : new String[0];
}
@Override
public String toString() {
return "SimpleDistributionRequest{" +
"requestType=" + requestType +
", paths=" + Arrays.toString(paths) +
'}';
}
private String[] sanitise(String[] paths) {
if (paths == null) return new String[] {};
List pathsOut = Arrays.asList(paths).stream().filter(this::notEmpty).collect(Collectors.toList());
return pathsOut.toArray(new String[] {});
}
private Set sanitise(Set paths) {
if (paths == null) return new HashSet<>();
return paths.stream().filter(this::notEmpty).collect(Collectors.toSet());
}
private boolean notEmpty(String path) {
return path != null && !path.trim().isEmpty();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy