001 /* 002 * Copyright 2011 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.kfs.sys.dataaccess; 017 018 import org.apache.ojb.broker.accesslayer.conversions.FieldConversion; 019 020 /** 021 * This class is intended to be used for inverting all the boolean values stored in the database before loading them into the 022 * business object and vice versa. This functionality is necessary for situations where a database table stores the opposite of the 023 * intented boolean attribute. An example is where a given business object has a pre-defined attribute, such as "inactive", while 024 * the user wishes to display the value as an 'active' indicator rather than an 'inactive indicator. Ideally, it would be better to 025 * replace the field in the database with the appropriate representation of the data so we do not have to perform these confusing 026 * conversions on data. Unfortunately, this is not always an option. 027 */ 028 public class OjbCharBooleanFieldInverseConversion implements FieldConversion { 029 030 private static final String TRUE = "Y"; 031 private static final String FALSE = "N"; 032 033 /** 034 * This method takes the value intended to be passed to the SQL statement and replaces that value with its inverse. Thus TRUE 035 * becomes FALSE and vice versa. 036 * 037 * @see org.apache.ojb.broker.accesslayer.conversions.FieldConversion#javaToSql(java.lang.Object) 038 */ 039 public Object javaToSql(Object source) { 040 if (source instanceof Boolean) { 041 if (source.equals(Boolean.TRUE)) { 042 return FALSE; 043 } 044 else { 045 return TRUE; 046 } 047 } 048 else if (source instanceof String) { 049 if ("Y".equalsIgnoreCase((String) source)) { 050 return FALSE; 051 } 052 else if ("N".equalsIgnoreCase((String) source)) { 053 return TRUE; 054 } 055 } 056 return source; 057 } 058 059 /** 060 * This method takes the value returned from the database and replaces it with its inverse, thus FALSE becomes TRUE and vice 061 * versa. 062 * 063 * @see org.apache.ojb.broker.accesslayer.conversions.FieldConversion#sqlToJava(java.lang.Object) 064 */ 065 public Object sqlToJava(Object source) { 066 if (source instanceof String) { 067 if (TRUE.equals(source)) { 068 return Boolean.FALSE; 069 } 070 else { 071 return Boolean.TRUE; 072 } 073 } 074 else { 075 return source; 076 } 077 } 078 079 }