1 /** 2 * Copyright 2005-2014 The Kuali Foundation 3 * 4 * Licensed under the Educational Community License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.opensource.org/licenses/ecl2.php 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 package org.kuali.rice.krad.uif.view; 17 18 import org.kuali.rice.kim.api.identity.Person; 19 import org.kuali.rice.krad.uif.container.CollectionGroup; 20 import org.kuali.rice.krad.uif.container.Group; 21 import org.kuali.rice.krad.uif.field.ActionField; 22 import org.kuali.rice.krad.uif.field.DataField; 23 import org.kuali.rice.krad.uif.field.Field; 24 import org.kuali.rice.krad.uif.field.InputField; 25 import org.kuali.rice.krad.uif.widget.Widget; 26 import org.kuali.rice.krad.web.form.UifFormBase; 27 28 import java.util.Set; 29 30 /** 31 * Performs user based authorization for actions and components contained in a {@link View} 32 * 33 * <p> 34 * Note only user authorization is done by the authorizer class. For non-user based logic, use the 35 * {@link ViewPresentationController} 36 * </p> 37 * 38 * @author Kuali Rice Team (rice.collab@kuali.org) 39 */ 40 public interface ViewAuthorizer { 41 42 /** 43 * Returns the set of action flags that are authorized for the given user 44 * 45 * <p> 46 * Action flags are created for views to indicate some action or feature should be enabled. These flags can be 47 * used within expressions for configuring the view content. 48 * 49 * For example: 50 * <bean parent="ActionField" p:methodToCall="save" p:actionLabel="save" 51 * p:render="@{#actionFlags[#Constants.KUALI_ACTION_CAN_SAVE]}"/> 52 * </p> 53 * 54 * <p> 55 * For each action flag, KIM is consulted to determine if a permission exist for the template associated with 56 * the action flag. If so, a check is then made to determine if the user has that permission. If the permission 57 * fails for the user, the action flag is removed from the returned set. 58 * </p> 59 * 60 * <p> 61 * The Set of available action flags should first be exported by the 62 * {@link ViewPresentationController#getActionFlags(View, org.kuali.rice.krad.web.form.UifFormBase)} method. The 63 * set returned from this method will be passed as the method argument here by the framework. 64 * </p> 65 * 66 * @param view - view instance the action flags apply to 67 * @param model - object containing the view data 68 * @param user - user we are authorizing the actions for 69 * @param actions - set of action flags to authorize 70 * @return Set<String> set of action flags that have been authorized, this will be equal to or a subset of the 71 * actions passed in 72 */ 73 public Set<String> getActionFlags(View view, ViewModel model, Person user, Set<String> actions); 74 75 /** 76 * Returns the set of edit modes that are authorized for the given user 77 * 78 * <p> 79 * An edit mode is a string that identifies a set of editable fields within the view. These are generally used 80 * when the entire view is not editable, but only certain fields. A field can be associated with an edit mode in 81 * two ways. The first is by using the edit mode in an expression when setting the field readOnly property. 82 * 83 * For example: 84 * <property name="readOnly" value="@{!#editModes['specialEdit'] and !fullEdit}" /> 85 * 86 * The second way is with the 87 * {@link ViewPresentationController#canEditField(View, ViewModel, org.kuali.rice.krad.uif.field.Field, String)} 88 * method which can look at the edit modes map on the view to determine if the given field should be editable. 89 * </p> 90 * 91 * <p> 92 * For each edit mode, KIM is consulted to determine if a permission exist for the 'Use View' template and 93 * the edit mode detail. If so, a check is then made to determine if the user has that permission. If the 94 * permission 95 * fails for the user, the edit mode is removed from the returned set. 96 * </p> 97 * 98 * <p> 99 * The Set of available edit modes should first be exported by the 100 * {@link ViewPresentationController#getEditModes(View, org.kuali.rice.krad.web.form.UifFormBase)} method. The 101 * set returned from this method will be passed as the method argument here by the framework. 102 * </p> 103 * 104 * @param view - view instance the edit modes apply to 105 * @param model - object containing the view data 106 * @param user - user we are authorizing the actions for 107 * @param editModes - set of edit modes to authorize 108 * @return Set<String> set of edit modes that have been authorized, this will be equal to or a subset of the 109 * edit mode set passed in 110 */ 111 public Set<String> getEditModes(View view, ViewModel model, Person user, Set<String> editModes); 112 113 /** 114 * Determines if the given user is authorized to open the given view 115 * 116 * @param view - view instance to check authorization for 117 * @param model - object containing the view data 118 * @param user - user to authorize 119 * @return boolean true if the user is authorized to open the view, false otherwise 120 */ 121 public boolean canOpenView(View view, ViewModel model, Person user); 122 123 /** 124 * Determines if the given user is authorized to edit the given view 125 * 126 * @param view - view instance to check authorization for 127 * @param model - object containing the view data 128 * @param user - user to authorize 129 * @return boolean true if the user is authorized to edit the view, false otherwise 130 */ 131 public boolean canEditView(View view, ViewModel model, Person user); 132 133 /** 134 * Checks whether the mask authorization exists for the given property and if so whether the given user has the 135 * ability to unmask the value 136 * 137 * @param view - view instance the field belongs to 138 * @param model - object containing the view data 139 * @param field - field associated for the property and from which the 140 * {@link org.kuali.rice.krad.uif.component.ComponentSecurity} will be retrieved 141 * @param propertyName - name of the property associated with the field 142 * @param user - user we are authorizing 143 * @return boolean true if the value can be unmasked, false if it should be masked 144 */ 145 public boolean canUnmaskField(View view, ViewModel model, DataField field, String propertyName, Person user); 146 147 /** 148 * Checks whether the partial mask authorization exists for the given property and if so whether the given user 149 * has the ability to unmask the value 150 * 151 * @param view - view instance the field belongs to 152 * @param model - object containing the view data 153 * @param field - field associated for the property and from which the 154 * {@link org.kuali.rice.krad.uif.component.ComponentSecurity} will be retrieved 155 * @param propertyName - name of the property associated with the field 156 * @param user - user we are authorizing 157 * @return boolean true if the value can be unmasked, false if it should be partially masked 158 */ 159 public boolean canPartialUnmaskField(View view, ViewModel model, DataField field, String propertyName, Person user); 160 161 public boolean canEditField(View view, ViewModel model, Field field, String propertyName, Person user); 162 163 public boolean canViewField(View view, ViewModel model, Field field, String propertyName, Person user); 164 165 public boolean canEditGroup(View view, ViewModel model, Group group, String groupId, Person user); 166 167 public boolean canViewGroup(View view, ViewModel model, Group group, String groupId, Person user); 168 169 public boolean canEditWidget(View view, ViewModel model, Widget widget, String widgetId, Person user); 170 171 public boolean canViewWidget(View view, ViewModel model, Widget widget, String widgetId, Person user); 172 173 public boolean canPerformAction(View view, ViewModel model, ActionField actionField, String actionEvent, 174 String actionId, Person user); 175 176 public boolean canEditLine(View view, ViewModel model, CollectionGroup collectionGroup, 177 String collectionPropertyName, Object line, Person user); 178 179 public boolean canViewLine(View view, ViewModel model, CollectionGroup collectionGroup, 180 String collectionPropertyName, Object line, Person user); 181 182 public boolean canEditLineField(View view, ViewModel model, CollectionGroup collectionGroup, 183 String collectionPropertyName, Object line, Field field, String propertyName, Person user); 184 185 public boolean canViewLineField(View view, ViewModel model, CollectionGroup collectionGroup, 186 String collectionPropertyName, Object line, Field field, String propertyName, Person user); 187 188 public boolean canPerformLineAction(View view, ViewModel model, CollectionGroup collectionGroup, 189 String collectionPropertyName, Object line, ActionField actionField, String actionEvent, String actionId, 190 Person user); 191 192 }