All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.adobe.acs.commons.oakpal.checks.AcsCommonsAuthorizableCompatibilityCheck Maven / Gradle / Ivy

The newest version!
/*
 * ACS AEM Commons
 *
 * Copyright (C) 2013 - 2023 Adobe
 *
 * Licensed 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 com.adobe.acs.commons.oakpal.checks;

import net.adamcin.oakpal.api.ProgressCheck;
import net.adamcin.oakpal.api.ProgressCheckFactory;
import net.adamcin.oakpal.api.Rule;
import net.adamcin.oakpal.api.Rules;
import net.adamcin.oakpal.api.Severity;
import net.adamcin.oakpal.api.SimpleProgressCheckFactoryCheck;
import org.apache.jackrabbit.api.JackrabbitSession;
import org.apache.jackrabbit.api.security.user.Authorizable;
import org.apache.jackrabbit.api.security.user.UserManager;
import org.apache.jackrabbit.vault.packaging.PackageId;

import javax.jcr.Node;
import javax.jcr.RepositoryException;
import javax.json.JsonObject;
import java.util.ArrayList;
import java.util.List;

import static net.adamcin.oakpal.api.JavaxJson.arrayOrEmpty;

/**
 * Checks the authorizableId of imported {@link Authorizable} nodes to ensure they do not begin with "acs-commons".
 * 

* {@code config} items: *

*
{@code scopeIds} ({@link Rule[]})
*
(default: include all) List of scope rules matching rep:authorizableId values for inclusion in the scope for * compatibility check.
*
*/ public final class AcsCommonsAuthorizableCompatibilityCheck implements ProgressCheckFactory { public static final String NT_REP_AUTHORIZABLE = "rep:Authorizable"; public static final String CONFIG_SCOPE_IDS = "scopeIds"; @Override public ProgressCheck newInstance(final JsonObject config) { final List scopeIds = Rules.fromJsonArray(arrayOrEmpty(config, CONFIG_SCOPE_IDS)); return new Check(scopeIds); } static final class Check extends SimpleProgressCheckFactoryCheck { private final List scopeIds; Check(final List scopeIds) { super(AcsCommonsAuthorizableCompatibilityCheck.class); this.scopeIds = new ArrayList<>(scopeIds); } @Override public void importedPath(final PackageId packageId, final String path, final Node node) throws RepositoryException { // fast check for authorizables if (node.isNodeType(NT_REP_AUTHORIZABLE)) { final UserManager userManager = ((JackrabbitSession) node.getSession()).getUserManager(); final Authorizable authz = userManager.getAuthorizableByPath(path); // if an authorizable is not loaded from the path, short circuit. if (authz != null) { final String id = authz.getID(); // check for inclusion based on authorizableId Rule lastMatched = Rules.lastMatch(scopeIds, id); // if id is excluded, short circuit if (lastMatched.isExclude()) { return; } if (id.startsWith("acs-commons")) { reporting(violation -> violation .withSeverity(Severity.MAJOR) .withPackage(packageId) .withDescription("{0}: reserved ID prefix [{1}]") .withArgument(path, id)); } } } } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy