/* * Copyright 2011 cruxframework.org. * * 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.cruxframework.crux.core.rebind.screen.widget.creator; import org.cruxframework.crux.core.client.permission.Permissions; import org.cruxframework.crux.core.client.utils.EscapeUtils; import org.cruxframework.crux.core.rebind.AbstractProxyCreator.SourcePrinter; import org.cruxframework.crux.core.rebind.screen.widget.AttributeProcessor; import org.cruxframework.crux.core.rebind.screen.widget.WidgetCreator; import org.cruxframework.crux.core.rebind.screen.widget.WidgetCreatorContext; import org.cruxframework.crux.core.rebind.screen.widget.declarative.TagAttribute; import org.cruxframework.crux.core.rebind.screen.widget.declarative.TagAttributes; /** * @author Thiago da Rosa de Bustamante * */ @TagAttributes({ @TagAttribute(value="enabled", type=Boolean.class, description="Sets whether this widget is enabled."), @TagAttribute(value="editPermission", type=String.class, processor=HasEnabledFactory.EditPermissionAttributeProcessor.class, supportsDataBinding=false, description="A role that must be checked to verify if user can edit this widget on the Screen. You must define a RoleManager to handle these permission validations.") }) public interface HasEnabledFactory<C extends WidgetCreatorContext> { /** * Process editPermission attribute * @author Thiago da Rosa de Bustamante * */ class EditPermissionAttributeProcessor extends AttributeProcessor<WidgetCreatorContext> { public EditPermissionAttributeProcessor(WidgetCreator<?> widgetCreator) { super(widgetCreator); } @Override public void processAttribute(SourcePrinter out, WidgetCreatorContext context, String attributeValue) { out.println("if (!"+Permissions.class.getCanonicalName()+".hasRole("+EscapeUtils.quote(attributeValue)+")){"); out.println(Permissions.class.getCanonicalName()+".markAsUnauthorizedForEdition("+context.getWidget()+");"); out.println("}"); } } }