/* 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 org.riotfamily.core.security.policy; import org.riotfamily.core.security.auth.RiotUser; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * A logging policy for debugging purposes. * * @since 6.5 * @author Alf Werder [alf dot werder at artundweise dot de] */ public class LoggingPolicy implements AuthorizationPolicy { private Logger log = LoggerFactory.getLogger(LoggingPolicy.class); private int order = org.springframework.core.Ordered.HIGHEST_PRECEDENCE; public int getOrder() { return this.order; } public void setOrder(int order) { this.order = order; } public Permission getPermission(RiotUser user, String action, Object object, Object context) { if (log.isDebugEnabled()) { log.debug(getMessage(action, object, context)); } return Permission.ABSTAIN; } private String getMessage(String action, Object object, Object context) { return String.format("action: %s, object: %s, context: %s", action, object, context); } }