001/* 002 * Copyright 2008 The Kuali Foundation 003 * 004 * Licensed under the Educational Community License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.opensource.org/licenses/ecl2.php 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016package org.kuali.ole.sys.document.authorization; 017 018import java.util.List; 019import java.util.Set; 020 021import org.kuali.ole.sys.businessobject.AccountingLine; 022import org.kuali.ole.sys.document.AccountingDocument; 023import org.kuali.ole.sys.document.web.AccountingLineRenderingContext; 024import org.kuali.ole.sys.document.web.AccountingLineViewAction; 025import org.kuali.rice.kim.api.identity.Person; 026 027/** 028 * Methods used to determine certain permissions associated with an accounting line. 029 */ 030public interface AccountingLineAuthorizer { 031 032 /** 033 * Determines which, if any, blocks whose children elements should not in any fashion be rendered 034 * 035 * @param accountingDocument the accounting document the line to authorize is owned by 036 * @param accountingLine the accounting line that is being authorized against 037 * @param newLine whether the line is a new line or not 038 * @return a Set of the names of blocks that should not being in any way rendered 039 */ 040 public abstract Set<String> getUnviewableBlocks(AccountingDocument accountingDocument, AccountingLine accountingLine, boolean newLine, Person currentUser); 041 042 /** 043 * Determines what actions are available to act upon the given accounting line 044 * 045 * @param accountingDocument the accounting document the line to authorize is owned by 046 * @param accountingLineRenderingContext a renderable context wrapping the accounting line that is being authorized against 047 * @param accountingLinePropertyName the name of the property that represents the accounting line 048 * @param lineIndex value, as Integer, of the index of the given accounting line within the group's collection of accounting 049 * lines; if null, then it is assumed that this is a new line 050 * @param groupTitle title of the group from the data dictionary 051 * @return a List of the Actions that are available for this line 052 */ 053 public abstract List<AccountingLineViewAction> getActions(AccountingDocument accountingDocument, AccountingLineRenderingContext accountingLineRenderingContext, String accountingLinePropertyName, Integer lineIndex, Person currentUser, String groupTitle); 054 055 /** 056 * Determines if new lines should be rendered for the given accounting line group (identified by its property name) 057 * 058 * @param accountingDocument the document that has accounting lines being authorized 059 * @param accountingGroupProperty the property of this accounting group 060 * @return true if new lines should be displayed, false otherwise 061 */ 062 public abstract boolean renderNewLine(AccountingDocument accountingDocument, String accountingGroupProperty); 063 064 /** 065 * Determines if any entire group is rendered as editable, which means that a new line will appear 066 * 067 * @param accountingDocument the accounting document which the collection of line are on 068 * @param accountingLineRenderingContexts the accounting lines of the group, wrapped in AccountingLineRenderingContext implementations 069 * @param currentUser the current user 070 * @return true if the group can be edited, false otherwise 071 */ 072 public abstract boolean isGroupEditable(AccountingDocument accountingDocument, List<? extends AccountingLineRenderingContext> accountingLineRenderingContexts, Person currentUser); 073 074 /** 075 * determine whether the current user has permission to edit the given field in the given accounting line 076 * 077 * @param accountingDocument the given accounting document 078 * @param accountingLine the given accounting line in the document 079 * @param accountingLineCollectionProperty the property of the collection the given accounting line is in 080 * @param fieldName the name of a field in the given accounting line 081 * @param editableLine whether the parent line of this field is editable 082 * @param editablePage whether the parent page of this field is editable 083 * @param currentUser the current user 084 * @return true if the the current user has permission to edit the given field in the given accounting line; otherwsie, false 085 */ 086 public abstract boolean hasEditPermissionOnField(AccountingDocument accountingDocument, AccountingLine accountingLine, String accountingLineCollectionProperty, String fieldName, boolean editableLine, boolean editablePage, Person currentUser); 087 088 /** 089 * determine whether the current user has permission to edit the given accounting line as a whole 090 * 091 * @param accountingDocument the given accounting document 092 * @param accountingLine the given accounting line in the document 093 * @param accountingLineCollectionProperty the property of the group that holds these accounting lines 094 * @param currentUser the current user 095 * @param pageIsEditable whether the current page is editable by the current user or not 096 * @return true if the the current user has permission to edit the given accounting line; otherwsie, false 097 */ 098 public abstract boolean hasEditPermissionOnAccountingLine(AccountingDocument accountingDocument, AccountingLine accountingLine, String accountingLineCollectionProperty, Person currentUser, boolean pageIsEditable); 099}