001 /** 002 * Copyright 2005-2013 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 */ 016 package org.kuali.rice.krad.test.document; 017 018 import org.kuali.rice.kim.api.identity.Person; 019 import org.kuali.rice.krad.document.SessionDocument; 020 import org.kuali.rice.krad.document.TransactionalDocumentBase; 021 import org.kuali.rice.krad.exception.PessimisticLockingException; 022 import org.kuali.rice.krad.test.document.bo.Account; 023 import org.kuali.rice.krad.util.GlobalVariables; 024 025 import java.util.ArrayList; 026 import java.util.List; 027 028 /** 029 * This is a test copy of AccountRequestDocument that has been modified to allow for custom lock descriptors. 030 * 031 * @author Kuali Rice Team (rice.collab@kuali.org) 032 */ 033 public class AccountRequestDocument2 extends TransactionalDocumentBase implements SessionDocument { 034 035 private static final long serialVersionUID = 7616690365412064056L; 036 037 /** 038 * A test key to map to some value indicating what fields the user can edit on this doc. Note that such behavior is not enforced; it is simply 039 * here for testing the PessimisticLockService's custom lock descriptor functionality. 040 */ 041 public static final String ACCT_REQ_DOC_2_EDITABLE_FIELDS = "acctReqDoc2EditableFields"; 042 /** 043 * A test value indicating that the user has permission to edit everything except "reason1" and "reason2". This is here only for testing the 044 * generation of custom lock descriptors for PessimisticLockServiceTest; AccountRequestDocument2 does not actually enforce any such behavior. 045 */ 046 public static final String EDIT_ALL_BUT_REASONS = "editAllButReasons"; 047 /** 048 * A test value indicating that the user only has permission to edit "reason1" and "reason2". This is here only for testing the generation of 049 * custom lock descriptors for PessimisticLockServiceTest; AccountRequestDocument2 does not actually enforce any such behavior. 050 */ 051 public static final String EDIT_REASONS_ONLY = "editReasonsOnly"; 052 053 private String requester; 054 private String reason1; 055 private String reason2; 056 private String requestType; 057 private String accountTypeCode; 058 059 private List<Account> accounts; 060 061 public AccountRequestDocument2() { 062 accounts = new ArrayList<Account>(); 063 } 064 065 public String getReason2() { 066 return reason2; 067 } 068 069 public void setReason2(String reason2) { 070 this.reason2 = reason2; 071 } 072 073 public String getReason1() { 074 return reason1; 075 } 076 077 public void setReason1(String reason1) { 078 this.reason1 = reason1; 079 } 080 081 public String getRequester() { 082 return requester; 083 } 084 085 public void setRequester(String requester) { 086 this.requester = requester; 087 } 088 089 public List<Account> getAccounts() { 090 return accounts; 091 } 092 093 public void setAccounts(List<Account> accounts) { 094 this.accounts = accounts; 095 } 096 097 public Account getAccount(int index) { 098 while(accounts.size() - 1 < index) { 099 accounts.add(new Account()); 100 } 101 return accounts.get(index); 102 } 103 104 public String getRequestType() { 105 return requestType; 106 } 107 108 public void setRequestType(String requestType) { 109 this.requestType = requestType; 110 } 111 112 public void setAccountTypeCode(String accountType) { 113 this.accountTypeCode = accountType; 114 } 115 116 public String getAccountTypeCode() { 117 return accountTypeCode; 118 } 119 120 /** 121 * Since this class was made to test custom lock descriptors, this method will always return true. 122 * 123 * @see org.kuali.rice.krad.document.DocumentBase#useCustomLockDescriptors() 124 */ 125 @Override 126 public boolean useCustomLockDescriptors() { 127 return true; 128 } 129 130 /** 131 * Generates a custom lock descriptor with a format of "[documentNumber]-[The user session's 'acctReqDoc2EditableFields' parameter value]". 132 * Will throw a PessimisticLockingException if this parameter is not defined or if its value is neither "editAllButReasons" nor "editReasonsOnly". 133 * 134 * @see org.kuali.rice.krad.document.DocumentBase#getCustomLockDescriptor(org.kuali.rice.kim.api.identity.Person) 135 */ 136 @Override 137 public String getCustomLockDescriptor(Person user) { 138 String editableFields = (String) GlobalVariables.getUserSession().retrieveObject(ACCT_REQ_DOC_2_EDITABLE_FIELDS); 139 if (editableFields == null) { 140 throw new PessimisticLockingException("The user session's '" + ACCT_REQ_DOC_2_EDITABLE_FIELDS + "' property cannot be null"); 141 } 142 else if (!EDIT_ALL_BUT_REASONS.equals(editableFields) && !EDIT_REASONS_ONLY.equals(editableFields)) { 143 throw new PessimisticLockingException("The value of the user session's '" + ACCT_REQ_DOC_2_EDITABLE_FIELDS + "' property is invalid"); 144 } 145 return getDocumentNumber() + "-" + editableFields; 146 } 147 }