blob: f07eef7c9567596df89e720cad6a37788ac1544d [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.feature.cpconverter.accesscontrol;
import org.apache.sling.feature.cpconverter.shared.RepoPath;
import java.util.LinkedList;
import java.util.List;
/**
* Simple single ACL statement representation.
*/
public final class AccessControlEntry {
private final boolean isAllow;
private final String privileges;
private final RepoPath repositoryPath;
private final List<String> restrictions = new LinkedList<>();
public AccessControlEntry(boolean isAllow, String privileges, RepoPath repositoryPath) {
this.isAllow = isAllow;
this.privileges = privileges;
this.repositoryPath = repositoryPath;
}
public void addRestriction(String restriction) {
if (restriction != null && !restriction.isEmpty()) {
restrictions.add(restriction);
}
}
public String getOperation() {
return isAllow ? "allow" : "deny";
}
public String getPrivileges() {
return privileges;
}
public RepoPath getRepositoryPath() {
return repositoryPath;
}
public List<String> getRestrictions() {
return restrictions;
}
@Override
public String toString() {
return "Acl [isAllow="
+ isAllow
+ ", privileges="
+ privileges
+ ", path="
+ repositoryPath
+ ", restrictions="
+ restrictions
+ "]";
}
}