All Downloads are FREE. Search and download functionalities are using the official Maven repository.

oracle.toplink.essentials.internal.helper.ConversionManager Maven / Gradle / Ivy

The newest version!
/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 * 
 * // Copyright (c) 1998, 2007, Oracle. All rights reserved.
 * 
 *
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License. You can obtain
 * a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
 * or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 * 
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
 * Sun designates this particular file as subject to the "Classpath" exception
 * as provided by Sun in the GPL Version 2 section of the License file that
 * accompanied this code.  If applicable, add the following below the License
 * Header, with the fields enclosed by brackets [] replaced by your own
 * identifying information: "Portions Copyrighted [year]
 * [name of copyright owner]"
 * 
 * Contributor(s):
 * 
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 */
package oracle.toplink.essentials.internal.helper;

import java.math.*;
import java.util.*;
import java.io.*;
import java.security.AccessController;
import java.security.PrivilegedActionException;
import java.sql.*;

import oracle.toplink.essentials.exceptions.*;
import oracle.toplink.essentials.internal.security.PrivilegedAccessHelper;
import oracle.toplink.essentials.internal.security.PrivilegedGetClassLoaderForClass;
import oracle.toplink.essentials.internal.security.PrivilegedGetContextClassLoader;

/**
 * 

* Purpose: Contains the conversion routines for some common classes in the system. * Primarly used to convert objects from a given database type to a different type in Java. * Uses a singleton instance, this is also used from the platform. *

* Responsibilities: *

    *
  • Execute the appropriate conversion routine. *
*/ public class ConversionManager implements Serializable, Cloneable { protected Map defaultNullValues; /** * This flag is here if the Conversion Manager should use the class loader on the * thread when loading classes. */ protected boolean shouldUseClassLoaderFromCurrentThread = false; protected static ConversionManager defaultManager; /** Allows the setting of a global default if no instance-level loader is set. */ private static ClassLoader defaultLoader; protected ClassLoader loader; /** Store the list of Classes that can be converted to from the key. */ protected Hashtable dataTypesConvertedFromAClass; /** Store the list of Classes that can be converted from to the key. */ protected Hashtable dataTypesConvertedToAClass; public ConversionManager() { this.defaultNullValues = new HashMap(5); this.dataTypesConvertedFromAClass = new Hashtable(); this.dataTypesConvertedToAClass = new Hashtable(); } /** * INTERNAL: */ public Object clone() { try { return super.clone(); } catch (CloneNotSupportedException exception) { return null; } } /** * Convert the object to the appropriate type by invoking the appropriate * ConversionManager method * @param object - the object that must be converted * @param javaClass - the class that the object must be converted to * @exception - ConversionException, all exceptions will be thrown as this type. * @return - the newly converted object */ public Object convertObject(Object sourceObject, Class javaClass) throws ConversionException { if (sourceObject == null) { // Check for default null conversion. // i.e. allow for null to be defaulted to "", or 0 etc. if (javaClass != null) { return getDefaultNullValue(javaClass); } else { return null; } } if ((sourceObject.getClass() == javaClass) || (javaClass == null) || (javaClass == ClassConstants.OBJECT) || (javaClass == ClassConstants.BLOB) || (javaClass == ClassConstants.CLOB) || ClassConstants.NOCONVERSION.isAssignableFrom(javaClass)) { return sourceObject; } // Check if object is instance of the real class for the primitive class. if (javaClass.isPrimitive() && (((sourceObject instanceof Boolean) && (javaClass == ClassConstants.PBOOLEAN)) || ((sourceObject instanceof Long) && (javaClass == ClassConstants.PLONG)) || ((sourceObject instanceof Integer) && (javaClass == ClassConstants.PINT)) || ((sourceObject instanceof Float) && (javaClass == ClassConstants.PFLOAT)) || ((sourceObject instanceof Double) && (javaClass == ClassConstants.PDOUBLE)) || ((sourceObject instanceof Byte) && (javaClass == ClassConstants.PBYTE)) || ((sourceObject instanceof Character) && (javaClass == ClassConstants.PCHAR)) || ((sourceObject instanceof Short) && (javaClass == ClassConstants.PSHORT)))) { return sourceObject; } try { if (javaClass == ClassConstants.STRING) { return convertObjectToString(sourceObject); } else if (javaClass == ClassConstants.UTILDATE) { return convertObjectToUtilDate(sourceObject); } else if (javaClass == ClassConstants.SQLDATE) { return convertObjectToDate(sourceObject); } else if (javaClass == ClassConstants.TIME) { return convertObjectToTime(sourceObject); } else if (javaClass == ClassConstants.TIMESTAMP) { return convertObjectToTimestamp(sourceObject); } else if ((javaClass == ClassConstants.CALENDAR) || (javaClass == ClassConstants.GREGORIAN_CALENDAR)) { return convertObjectToCalendar(sourceObject); } else if ((javaClass == ClassConstants.CHAR) || (javaClass == ClassConstants.PCHAR)) { return convertObjectToChar(sourceObject); } else if ((javaClass == ClassConstants.INTEGER) || (javaClass == ClassConstants.PINT)) { return convertObjectToInteger(sourceObject); } else if ((javaClass == ClassConstants.DOUBLE) || (javaClass == ClassConstants.PDOUBLE)) { return convertObjectToDouble(sourceObject); } else if ((javaClass == ClassConstants.FLOAT) || (javaClass == ClassConstants.PFLOAT)) { return convertObjectToFloat(sourceObject); } else if ((javaClass == ClassConstants.LONG) || (javaClass == ClassConstants.PLONG)) { return convertObjectToLong(sourceObject); } else if ((javaClass == ClassConstants.SHORT) || (javaClass == ClassConstants.PSHORT)) { return convertObjectToShort(sourceObject); } else if ((javaClass == ClassConstants.BYTE) || (javaClass == ClassConstants.PBYTE)) { return convertObjectToByte(sourceObject); } else if (javaClass == ClassConstants.BIGINTEGER) { return convertObjectToBigInteger(sourceObject); } else if (javaClass == ClassConstants.BIGDECIMAL) { return convertObjectToBigDecimal(sourceObject); } else if (javaClass == ClassConstants.NUMBER) { return convertObjectToNumber(sourceObject); } else if ((javaClass == ClassConstants.BOOLEAN) || (javaClass == ClassConstants.PBOOLEAN)) { return convertObjectToBoolean(sourceObject); } else if (javaClass == ClassConstants.APBYTE) { return convertObjectToByteArray(sourceObject); } else if (javaClass == ClassConstants.ABYTE) { return convertObjectToByteObjectArray(sourceObject); } else if (javaClass == ClassConstants.APCHAR) { return convertObjectToCharArray(sourceObject); } else if (javaClass == ClassConstants.ACHAR) { return convertObjectToCharacterArray(sourceObject); } else if ((sourceObject.getClass() == ClassConstants.STRING) && (javaClass == ClassConstants.CLASS)) { return convertObjectToClass(sourceObject); } } catch (ConversionException ce) { throw ce; } catch (Exception e) { throw ConversionException.couldNotBeConverted(sourceObject, javaClass, e); } // Delay this check as poor performance. if (javaClass.isInstance(sourceObject)) { return sourceObject; } throw ConversionException.couldNotBeConverted(sourceObject, javaClass); } /** * Build a valid instance of BigDecimal from the given sourceObject * @param sourceObject Valid instance of String, BigInteger, any Number */ protected BigDecimal convertObjectToBigDecimal(Object sourceObject) throws ConversionException { BigDecimal bigDecimal = null; try { if (sourceObject instanceof String) { bigDecimal = new BigDecimal((String)sourceObject); } else if (sourceObject instanceof BigInteger) { bigDecimal = new BigDecimal((BigInteger)sourceObject); } else if (sourceObject instanceof Number) { bigDecimal = new BigDecimal(((Number)sourceObject).doubleValue()); } else { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.BIGDECIMAL); } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.BIGDECIMAL, exception); } return bigDecimal; } /** * Build a valid instance of BigInteger from the provided sourceObject. * @param sourceObject Valid instance of String, BigDecimal, or any Number */ protected BigInteger convertObjectToBigInteger(Object sourceObject) throws ConversionException { BigInteger bigInteger = null; try { if (sourceObject instanceof BigInteger) { bigInteger = (BigInteger)sourceObject; } else if (sourceObject instanceof String) { bigInteger = new BigInteger((String)sourceObject); } else if (sourceObject instanceof BigDecimal) { bigInteger = ((BigDecimal)sourceObject).toBigInteger(); } else if (sourceObject instanceof Number) { bigInteger = new BigInteger(new Long(((Number)sourceObject).longValue()).toString()); } else { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.BIGINTEGER); } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.BIGINTEGER, exception); } return bigInteger; } /** * Build a valid instance of Boolean from the source object. * 't', 'T', "true", "TRUE", 1,'1' -> Boolean(true) * 'f', 'F', "false", "FALSE", 0 ,'0' -> Boolean(false) */ protected Boolean convertObjectToBoolean(Object sourceObject) { if (sourceObject instanceof Character) { switch (Character.toLowerCase(((Character)sourceObject).charValue())) { case '1': case 't': return new Boolean(true); case '0': case 'f': return new Boolean(false); } } if (sourceObject instanceof String) { String stringValue = ((String)sourceObject).toLowerCase(); if (stringValue.equals("t") || stringValue.equals("true") || stringValue.equals("1")) { return new Boolean(true); } else if (stringValue.equals("f") || stringValue.equals("false") || stringValue.equals("0")) { return new Boolean(false); } } if (sourceObject instanceof Number) { int intValue = ((Number)sourceObject).intValue(); if (intValue != 0) { return new Boolean(true); } else if (intValue == 0) { return new Boolean(false); } } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.BOOLEAN); } /** * Build a valid instance of Byte from the provided sourceObject * @param sourceObject Valid instance of String or any Number * @caught exception The Byte(String) constructer throws a * NumberFormatException if the String does not contain a * parsable byte. * */ protected Byte convertObjectToByte(Object sourceObject) throws ConversionException { try { if (sourceObject instanceof String) { return new Byte((String)sourceObject); } if (sourceObject instanceof Number) { return new Byte(((Number)sourceObject).byteValue()); } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.BYTE, exception); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.BYTE); } /** * Build a valid instance of a byte array from the given object. * This method does hex conversion of the string values. Some * databases have problems with storing blobs unless the blob * is stored as a hex string. */ protected byte[] convertObjectToByteArray(Object sourceObject) throws ConversionException { //Bug#3128838 Used when converted to Byte[] if (sourceObject instanceof byte[]) { return (byte[])sourceObject; //Related to Bug#3128838. Add support to convert to Byte[] } else if (sourceObject instanceof Byte[]) { Byte[] objectBytes = (Byte[])sourceObject; byte[] bytes = new byte[objectBytes.length]; for (int index = 0; index < objectBytes.length; index++) { bytes[index] = objectBytes[index].byteValue(); } return bytes; } else if (sourceObject instanceof String) { return Helper.buildBytesFromHexString((String)sourceObject); } else if (sourceObject instanceof Blob) { Blob blob = (Blob)sourceObject; try { return blob.getBytes(1L, (int)blob.length()); } catch (SQLException exception) { throw DatabaseException.sqlException(exception); } } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.APBYTE); } /** * Build a valid instance of a Byte array from the given object. * This method does hex conversion of the string values. Some * databases have problems with storing blobs unless the blob * is stored as a hex string. */ protected Byte[] convertObjectToByteObjectArray(Object sourceObject) throws ConversionException { byte[] bytes = convertObjectToByteArray(sourceObject); Byte[] objectBytes = new Byte[bytes.length]; for (int index = 0; index < bytes.length; index++) { objectBytes[index] = new Byte(bytes[index]); } return objectBytes; } /** * Build a valid instance of java.util.Calendar from the given source object. * @param sourceObject Valid instance of java.util.Date, String, java.sql.Timestamp, or Long */ protected Calendar convertObjectToCalendar(Object sourceObject) throws ConversionException { if (sourceObject instanceof Calendar) { return (Calendar)sourceObject; } else if (sourceObject instanceof java.util.Date) { // PERF: Avoid double conversion for date subclasses. return Helper.calendarFromUtilDate((java.util.Date)sourceObject); } return Helper.calendarFromUtilDate(convertObjectToUtilDate(sourceObject)); } /** * Build a valid instance of Character from the provided sourceObject. * @param sourceObject Valid instance of String or any Number */ protected Character convertObjectToChar(Object sourceObject) throws ConversionException { if (sourceObject instanceof String) { if (((String)sourceObject).length() < 1) { return null; } return new Character(((String)sourceObject).charAt(0)); } if (sourceObject instanceof Number) { return new Character((char)((Number)sourceObject).byteValue()); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.CHAR); } /** * Build a valid instance of a Character array from the given object. */ protected Character[] convertObjectToCharacterArray(Object sourceObject) throws ConversionException { String stringValue = convertObjectToString(sourceObject); Character[] chars = new Character[stringValue.length()]; for (int index = 0; index < stringValue.length(); index++) { chars[index] = new Character(stringValue.charAt(index)); } return chars; } /** * Build a valid instance of a char array from the given object. */ protected char[] convertObjectToCharArray(Object sourceObject) throws ConversionException { if (sourceObject instanceof Character[]) { Character[] objectChars = (Character[])sourceObject; char[] chars = new char[objectChars.length]; for (int index = 0; index < objectChars.length; index++) { chars[index] = objectChars[index].charValue(); } return chars; } String stringValue = convertObjectToString(sourceObject); char[] chars = new char[stringValue.length()]; for (int index = 0; index < stringValue.length(); index++) { chars[index] = stringValue.charAt(index); } return chars; } /** * Build a valid Class from the string that is passed in * @param sourceObject Valid instance of String */ protected Class convertObjectToClass(Object sourceObject) throws ConversionException { Class theClass = null; if (!(sourceObject instanceof String)) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.CLASS); } try { // bug # 2799318 theClass = getPrimitiveClass((String)sourceObject); if (theClass == null) { theClass = Class.forName((String)sourceObject, true, getLoader()); } } catch (Exception exception) { throw ConversionException.couldNotBeConvertedToClass(sourceObject, ClassConstants.CLASS, exception); } return theClass; } /** * Convert the object to an instance of java.sql.Date. * @param sourceObject Object of type java.sql.Timestamp, java.util.Date, String or Long */ protected java.sql.Date convertObjectToDate(Object sourceObject) throws ConversionException { java.sql.Date date = null; Class sourceClass = sourceObject.getClass(); if (sourceObject instanceof java.sql.Date) { date = (java.sql.Date)sourceObject;//Helper date is not caught on class check. } else if (sourceObject instanceof java.sql.Timestamp) { date = Helper.dateFromTimestamp((java.sql.Timestamp)sourceObject); } else if (sourceObject.getClass() == ClassConstants.UTILDATE) { date = Helper.sqlDateFromUtilDate((java.util.Date)sourceObject); } else if (sourceObject instanceof Calendar) { return Helper.dateFromCalendar((Calendar)sourceObject); } else if (sourceObject instanceof String) { date = Helper.dateFromString((String)sourceObject); } else if (sourceObject instanceof Long) { date = Helper.dateFromLong((Long)sourceObject); } else { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.SQLDATE); } return date; } /** * Convert the object to an instance of Double. * @param sourceObject Object of type String or Number. * @caught exception The Double(String) constructer throws a * NumberFormatException if the String does not contain a * parsable double. */ protected Double convertObjectToDouble(Object sourceObject) throws ConversionException { try { if (sourceObject instanceof String) { return new Double((String)sourceObject); } if (sourceObject instanceof Number) { return new Double(((Number)sourceObject).doubleValue()); } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.DOUBLE, exception); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.DOUBLE); } /** * Build a valid Float instance from a String or another Number instance. * @caught exception The Float(String) constructer throws a * NumberFormatException if the String does not contain a * parsable Float. */ protected Float convertObjectToFloat(Object sourceObject) throws ConversionException { try { if (sourceObject instanceof String) { return new Float((String)sourceObject); } if (sourceObject instanceof Number) { return new Float(((Number)sourceObject).floatValue()); } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.FLOAT, exception); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.FLOAT); } /** * Build a valid Integer instance from a String or another Number instance. * @caught exception The Integer(String) constructer throws a * NumberFormatException if the String does not contain a * parsable integer. */ protected Integer convertObjectToInteger(Object sourceObject) throws ConversionException { try { if (sourceObject instanceof String) { return new Integer((String)sourceObject); } if (sourceObject instanceof Number) { return new Integer(((Number)sourceObject).intValue()); } if (sourceObject instanceof Boolean) { if (((Boolean)sourceObject).booleanValue()) { return new Integer(1); } else { return new Integer(0); } } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.INTEGER, exception); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.INTEGER); } /** * Build a valid Long instance from a String or another Number instance. * @caught exception The Long(String) constructer throws a * NumberFormatException if the String does not contain a * parsable long. * */ protected Long convertObjectToLong(Object sourceObject) throws ConversionException { try { if (sourceObject instanceof String) { return new Long((String)sourceObject); } if (sourceObject instanceof Number) { return new Long(((Number)sourceObject).longValue()); } if (sourceObject instanceof java.util.Date) { return new Long(((java.util.Date)sourceObject).getTime()); } if (sourceObject instanceof java.util.Calendar) { return new Long(JavaPlatform.getTimeInMillis(((java.util.Calendar)sourceObject))); } if (sourceObject instanceof Boolean) { if (((Boolean)sourceObject).booleanValue()) { return new Long(1); } else { return new Long(0); } } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.LONG, exception); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.LONG); } /** * INTERNAL: * Build a valid BigDecimal instance from a String or another * Number instance. BigDecimal is the most general type so is * must be returned when an object is converted to a number. * @caught exception The BigDecimal(String) constructer throws a * NumberFormatException if the String does not contain a * parsable BigDecimal. */ protected BigDecimal convertObjectToNumber(Object sourceObject) throws ConversionException { try { if (sourceObject instanceof String) { return new BigDecimal((String)sourceObject); } if (sourceObject instanceof Number) { return new BigDecimal(((Number)sourceObject).doubleValue()); } if (sourceObject instanceof Boolean) { if (((Boolean)sourceObject).booleanValue()) { return new BigDecimal(1); } else { return new BigDecimal(0); } } } catch (NumberFormatException exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.NUMBER, exception); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.NUMBER); } /** * INTERNAL: * Build a valid Short instance from a String or another Number instance. * @caught exception The Short(String) constructer throws a * NumberFormatException if the String does not contain a * parsable short. */ protected Short convertObjectToShort(Object sourceObject) throws ConversionException { try { if (sourceObject instanceof String) { return new Short((String)sourceObject); } if (sourceObject instanceof Number) { return new Short(((Number)sourceObject).shortValue()); } if (sourceObject instanceof Boolean) { if (((Boolean)sourceObject).booleanValue()) { return new Short((short)1); } else { return new Short((short)0); } } } catch (Exception exception) { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.SHORT, exception); } throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.SHORT); } /** * INTERNAL: * Converts objects to thier string representations. java.util.Date * is converted to a timestamp first and then to a string. An array * of bytes is converted to a hex string. */ protected String convertObjectToString(Object sourceObject) throws ConversionException { if (sourceObject.getClass() == ClassConstants.UTILDATE) { return Helper.printTimestamp(Helper.timestampFromDate((java.util.Date)sourceObject)); } else if (sourceObject instanceof Calendar) { return Helper.printCalendar((Calendar)sourceObject); } else if (sourceObject instanceof java.sql.Timestamp) { return Helper.printTimestamp((java.sql.Timestamp)sourceObject); } else if (sourceObject instanceof java.sql.Date) { return Helper.printDate((java.sql.Date)sourceObject); } else if (sourceObject instanceof java.sql.Time) { return Helper.printTime((java.sql.Time)sourceObject); } else if (sourceObject instanceof byte[]) { return Helper.buildHexStringFromBytes((byte[])sourceObject); //Bug#3854296 Added support to convert Byte[], char[] and Character[] to String correctly } else if (sourceObject instanceof Byte[]) { return Helper.buildHexStringFromBytes(convertObjectToByteArray(sourceObject)); } else if (sourceObject instanceof char[]) { return new String((char[])sourceObject); } else if (sourceObject instanceof Character[]) { return new String(convertObjectToCharArray(sourceObject)); } else if (sourceObject instanceof Class) { return ((Class)sourceObject).getName(); } else if (sourceObject instanceof Character) { return sourceObject.toString(); } else if (sourceObject instanceof Clob) { Clob clob = (Clob)sourceObject; try { return clob.getSubString(1L, (int)clob.length()); } catch (SQLException exception) { throw DatabaseException.sqlException(exception); } } return sourceObject.toString(); } /** * INTERNAL: * Build a valid instance of java.sql.Time from the given source object. * @param sourceObject Valid instance of java.sql.Time, String, java.util.Date, java.sql.Timestamp, or Long */ protected java.sql.Time convertObjectToTime(Object sourceObject) throws ConversionException { java.sql.Time time = null; if (sourceObject instanceof java.sql.Time) { return (java.sql.Time)sourceObject;//Helper timestamp is not caught on class check. } if (sourceObject instanceof String) { time = Helper.timeFromString((String)sourceObject); } else if (sourceObject.getClass() == ClassConstants.UTILDATE) { time = Helper.timeFromDate((java.util.Date)sourceObject); } else if (sourceObject instanceof java.sql.Timestamp) { time = Helper.timeFromTimestamp((java.sql.Timestamp)sourceObject); } else if (sourceObject instanceof Calendar) { return Helper.timeFromCalendar((Calendar)sourceObject); } else if (sourceObject instanceof Long) { time = Helper.timeFromLong((Long)sourceObject); } else { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.TIME); } return time; } /** * INTERNAL: * Build a valid instance of java.sql.Timestamp from the given source object. * @param sourceObject Valid obejct of class java.sql.Timestamp, String, java.util.Date, or Long */ protected java.sql.Timestamp convertObjectToTimestamp(Object sourceObject) throws ConversionException { java.sql.Timestamp timestamp = null; if (sourceObject instanceof java.sql.Timestamp) { return (java.sql.Timestamp)sourceObject;// Helper timestamp is not caught on class check. } if (sourceObject instanceof String) { timestamp = Helper.timestampFromString((String)sourceObject); } else if (sourceObject instanceof java.util.Date) {// This handles all date and subclasses, sql.Date, sql.Time conversions. timestamp = Helper.timestampFromDate((java.util.Date)sourceObject); } else if (sourceObject instanceof Calendar) { return Helper.timestampFromCalendar((Calendar)sourceObject); } else if (sourceObject instanceof Long) { timestamp = Helper.timestampFromLong((Long)sourceObject); } else { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.TIMESTAMP); } return timestamp; } /** * INTERNAL: * Build a valid instance of java.util.Date from the given source object. * @param sourceObject Valid instance of java.util.Date, String, java.sql.Timestamp, or Long */ protected java.util.Date convertObjectToUtilDate(Object sourceObject) throws ConversionException { java.util.Date date = null; if (sourceObject.getClass() == java.util.Date.class) { date = (java.util.Date)sourceObject;//used when converting util.Date to Calendar } else if (sourceObject instanceof java.sql.Date) { date = Helper.utilDateFromSQLDate((java.sql.Date)sourceObject); } else if (sourceObject instanceof java.sql.Time) { date = Helper.utilDateFromTime((java.sql.Time)sourceObject); } else if (sourceObject instanceof String) { date = Helper.utilDateFromTimestamp(Helper.timestampFromString((String)sourceObject)); } else if (sourceObject instanceof java.sql.Timestamp) { date = Helper.utilDateFromTimestamp((java.sql.Timestamp)sourceObject); } else if (sourceObject instanceof Calendar) { return ((Calendar)sourceObject).getTime(); } else if (sourceObject instanceof Long) { date = Helper.utilDateFromLong((Long)sourceObject); } else { throw ConversionException.couldNotBeConverted(sourceObject, ClassConstants.UTILDATE); } return date; } /** * PUBLIC: * Resolve the given String className into a class using this * ConversionManager's classloader. */ public Class convertClassNameToClass(String className) throws ConversionException { return convertObjectToClass(className); } /** * A singleton conversion manager is used to handle generic converisons. * This should not be used for conversion under the session context, thse must go through the platform. * This allows for the singleton to be customized through setting the default to a user defined subclass. */ public static ConversionManager getDefaultManager() { if (defaultManager == null) { setDefaultManager(new ConversionManager()); defaultManager.setShouldUseClassLoaderFromCurrentThread(true); } return defaultManager; } /** * INTERNAL: * Allow for the null values for classes to be defaulted in one place. * Any nulls read from the database to be converted to the class will be given the specified null value. */ public Object getDefaultNullValue(Class theClass) { return getDefaultNullValues().get(theClass); } /** * INTERNAL: * Allow for the null values for classes to be defaulted in one place. * Any nulls read from the database to be converted to the class will be given the specified null value. */ public Map getDefaultNullValues() { return defaultNullValues; } /** * INTERNAL: */ public ClassLoader getLoader() { if (shouldUseClassLoaderFromCurrentThread()) { if (PrivilegedAccessHelper.shouldUsePrivilegedAccess()){ try { return (ClassLoader)AccessController.doPrivileged(new PrivilegedGetContextClassLoader(Thread.currentThread())); } catch (PrivilegedActionException exception) { // should not be thrown } } else { return PrivilegedAccessHelper.getContextClassLoader(Thread.currentThread()); } } if (loader == null) { if (defaultLoader == null) { //CR 2621 ClassLoader loader = null; if (PrivilegedAccessHelper.shouldUsePrivilegedAccess()){ try{ loader = (ClassLoader)AccessController.doPrivileged(new PrivilegedGetClassLoaderForClass(ClassConstants.ConversionManager_Class)); } catch (PrivilegedActionException exc){ // will not be thrown } } else { loader = PrivilegedAccessHelper.getClassLoaderForClass(ClassConstants.ConversionManager_Class); } setLoader(loader); } else { setLoader(getDefaultLoader()); } } return loader; } /** * INTERNAL: * Load the class using the default managers class loader. * This is a thread based class loader by default. * This should be used to load all classes as Class.forName can only * see classes on the same classpath as the toplink.jar. */ public static Class loadClass(String className) { return (Class)getDefaultManager().convertObject(className, ClassConstants.CLASS); } /** * INTERNAL: * This is used to determine the wrapper class for a primitive. */ public static Class getObjectClass(Class javaClass) { // Null means unknown always for classifications. if (javaClass == null) { return null; } if (javaClass.isPrimitive()) { if (javaClass == ClassConstants.PCHAR) { return ClassConstants.CHAR; } if (javaClass == ClassConstants.PINT) { return ClassConstants.INTEGER; } if (javaClass == ClassConstants.PDOUBLE) { return ClassConstants.DOUBLE; } if (javaClass == ClassConstants.PFLOAT) { return ClassConstants.FLOAT; } if (javaClass == ClassConstants.PLONG) { return ClassConstants.LONG; } if (javaClass == ClassConstants.PSHORT) { return ClassConstants.SHORT; } if (javaClass == ClassConstants.PBYTE) { return ClassConstants.BYTE; } if (javaClass == ClassConstants.PBOOLEAN) { return ClassConstants.BOOLEAN; } } else if (javaClass == ClassConstants.APBYTE) { return ClassConstants.APBYTE; } else if (javaClass == ClassConstants.APCHAR) { return ClassConstants.APCHAR; } else { return javaClass; } return javaClass; } /** * INTERNAL: * Returns a class based on the passed in string. */ public static Class getPrimitiveClass(String classType) { if (classType.equals("int")) { return Integer.TYPE; } else if (classType.equals("boolean")) { return Boolean.TYPE; } else if (classType.equals("char")) { return Character.TYPE; } else if (classType.equals("short")) { return Short.TYPE; } else if (classType.equals("byte")) { return Byte.TYPE; } else if (classType.equals("float")) { return Float.TYPE; } else if (classType.equals("double")) { return Double.TYPE; } else if (classType.equals("long")) { return Long.TYPE; } return null; } /** * A singleton conversion manager is used to handle generic converisons. * This should not be used for conversion under the session context, thse must go through the platform. * This allows for the singleton to be customized through setting the default to a user defined subclass. */ public static void setDefaultManager(ConversionManager theManager) { defaultManager = theManager; } /** * INTERNAL: * Allow for the null values for classes to be defaulted in one place. * Any nulls read from the database to be converted to the class will be given the specified null value. * Primitive null values should be set to the wrapper class. */ public void setDefaultNullValue(Class theClass, Object theValue) { getDefaultNullValues().put(theClass, theValue); } /** * INTERNAL: * Allow for the null values for classes to be defaulted in one place. * Any nulls read from the database to be converted to the class will be given the specified null value. */ public void setDefaultNullValues(Map defaultNullValues) { this.defaultNullValues = defaultNullValues; } /** * INTERNAL: * @parameter java.lang.ClassLoader */ public void setLoader(ClassLoader classLoader) { shouldUseClassLoaderFromCurrentThread = false; loader = classLoader; } /** * INTERNAL: * Set the default class loader to use if no instance-level loader is set * @parameter java.lang.ClassLoader */ public static void setDefaultLoader(ClassLoader classLoader) { defaultLoader = classLoader; } /** * INTERNAL: * Get the default class loader to use if no instance-level loader is set * @return java.lang.ClassLoader */ public static ClassLoader getDefaultLoader() { return defaultLoader; } /** * ADVANCED: * This flag should be set if the current thread classLoader should be used. * This is the case in certain Application Servers were the class loader must be * retreived from the current Thread. If classNotFoundExceptions are being thrown then set * this flag. In certain cases it will resolve the problem */ public void setShouldUseClassLoaderFromCurrentThread(boolean useCurrentThread) { this.shouldUseClassLoaderFromCurrentThread = useCurrentThread; } /** * ADVANCED: * This flag should be set if the current thread classLoader should be used. * This is the case in certain Application Servers were the class loader must be * retreived from the current Thread. If classNotFoundExceptions are being thrown then set * this flag. In certain cases it will resolve the problem */ public boolean shouldUseClassLoaderFromCurrentThread() { return this.shouldUseClassLoaderFromCurrentThread; } /** * PUBLIC: * Return the list of Classes that can be converted to from the passed in javaClass. * @param javaClass - the class that is converted from * @return - a vector of classes */ public Vector getDataTypesConvertedFrom(Class javaClass) { if (dataTypesConvertedFromAClass.isEmpty()) { buildDataTypesConvertedFromAClass(); } return (Vector)dataTypesConvertedFromAClass.get(javaClass); } /** * PUBLIC: * Return the list of Classes that can be converted from to the passed in javaClass. * @param javaClass - the class that is converted to * @return - a vector of classes */ public Vector getDataTypesConvertedTo(Class javaClass) { if (dataTypesConvertedToAClass.isEmpty()) { buildDataTypesConvertedToAClass(); } return (Vector)dataTypesConvertedToAClass.get(javaClass); } protected Vector buildNumberVec() { Vector vec = new Vector(); vec.addElement(BigInteger.class); vec.addElement(BigDecimal.class); vec.addElement(Byte.class); vec.addElement(Double.class); vec.addElement(Float.class); vec.addElement(Integer.class); vec.addElement(Long.class); vec.addElement(Short.class); vec.addElement(Number.class); return vec; } protected Vector buildDateTimeVec() { Vector vec = new Vector(); vec.addElement(java.util.Date.class); vec.addElement(Timestamp.class); vec.addElement(Calendar.class); return vec; } protected void buildDataTypesConvertedFromAClass() { dataTypesConvertedFromAClass.put(BigDecimal.class, buildFromBigDecimalVec()); dataTypesConvertedFromAClass.put(BigInteger.class, buildFromBigIntegerVec()); dataTypesConvertedFromAClass.put(Blob.class, buildFromBlobVec()); dataTypesConvertedFromAClass.put(Boolean.class, buildFromBooleanVec()); dataTypesConvertedFromAClass.put(byte[].class, buildFromByteArrayVec()); dataTypesConvertedFromAClass.put(Byte.class, buildFromByteVec()); dataTypesConvertedFromAClass.put(Calendar.class, buildFromCalendarVec()); dataTypesConvertedFromAClass.put(Character.class, buildFromCharacterVec()); dataTypesConvertedFromAClass.put(Clob.class, buildFromClobVec()); dataTypesConvertedFromAClass.put(java.sql.Date.class, buildFromDateVec()); dataTypesConvertedFromAClass.put(Double.class, buildFromDoubleVec()); dataTypesConvertedFromAClass.put(Float.class, buildFromFloatVec()); dataTypesConvertedFromAClass.put(Integer.class, buildFromIntegerVec()); dataTypesConvertedFromAClass.put(Long.class, buildFromLongVec()); dataTypesConvertedFromAClass.put(Number.class, buildFromNumberVec()); dataTypesConvertedFromAClass.put(Short.class, buildFromShortVec()); dataTypesConvertedFromAClass.put(String.class, buildFromStringVec()); dataTypesConvertedFromAClass.put(Timestamp.class, buildFromTimestampVec()); dataTypesConvertedFromAClass.put(Time.class, buildFromTimeVec()); dataTypesConvertedFromAClass.put(java.util.Date.class, buildFromUtilDateVec()); dataTypesConvertedFromAClass.put(Byte[].class, buildFromByteObjectArraryVec()); dataTypesConvertedFromAClass.put(char[].class, buildFromCharArrayVec()); dataTypesConvertedFromAClass.put(Character[].class, buildFromCharacterArrayVec()); } protected Vector buildFromBooleanVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(Boolean.class); vec.addElement(Integer.class); vec.addElement(Long.class); vec.addElement(Short.class); vec.addElement(Number.class); vec.addElement(Character[].class); vec.addElement(char[].class); vec.addElement(boolean.class); vec.addElement(int.class); vec.addElement(long.class); vec.addElement(short.class); return vec; } protected Vector buildFromNumberVec() { Vector vec = buildNumberVec(); vec.addElement(String.class); vec.addElement(Character.class); vec.addElement(Boolean.class); vec.addElement(Character[].class); vec.addElement(char[].class); vec.addElement(char.class); vec.addElement(int.class); vec.addElement(double.class); vec.addElement(float.class); vec.addElement(long.class); vec.addElement(short.class); vec.addElement(byte.class); vec.addElement(boolean.class); return vec; } protected Vector buildFromBigDecimalVec() { return buildFromNumberVec(); } protected Vector buildFromBigIntegerVec() { return buildFromNumberVec(); } protected Vector buildFromIntegerVec() { return buildFromNumberVec(); } protected Vector buildFromFloatVec() { return buildFromNumberVec(); } protected Vector buildFromDoubleVec() { return buildFromNumberVec(); } protected Vector buildFromShortVec() { return buildFromNumberVec(); } protected Vector buildFromByteVec() { return buildFromNumberVec(); } protected Vector buildFromLongVec() { Vector vec = buildFromNumberVec(); vec.addAll(buildDateTimeVec()); vec.addElement(java.sql.Date.class); vec.addElement(Time.class); return vec; } protected Vector buildFromStringVec() { Vector vec = buildFromLongVec(); vec.addElement(Byte[].class); vec.addElement(byte[].class); vec.addElement(Clob.class); return vec; } protected Vector buildFromCharacterVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(Boolean.class); vec.addElement(Character[].class); vec.addElement(Character.class); vec.addElement(char[].class); vec.addElement(char.class); vec.addElement(boolean.class); return vec; } protected Vector buildFromByteArrayVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(byte[].class); vec.addElement(Byte[].class); vec.addElement(Character[].class); vec.addElement(char[].class); return vec; } protected Vector buildFromClobVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(Character[].class); vec.addElement(char[].class); return vec; } protected Vector buildFromBlobVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(Byte[].class); vec.addElement(byte[].class); vec.addElement(Character[].class); vec.addElement(char[].class); return vec; } protected Vector buildFromUtilDateVec() { Vector vec = buildDateTimeVec(); vec.addElement(String.class); vec.addElement(Long.class); vec.addElement(java.sql.Date.class); vec.addElement(Time.class); vec.addElement(long.class); vec.addElement(Character[].class); vec.addElement(char[].class); return vec; } protected Vector buildFromTimestampVec() { return buildFromUtilDateVec(); } protected Vector buildFromCalendarVec() { return buildFromUtilDateVec(); } protected Vector buildFromDateVec() { Vector vec = buildDateTimeVec(); vec.addElement(String.class); vec.addElement(Long.class); vec.addElement(java.sql.Date.class); vec.addElement(long.class); vec.addElement(Character[].class); vec.addElement(char[].class); return vec; } protected Vector buildFromTimeVec() { Vector vec = buildDateTimeVec(); vec.addElement(String.class); vec.addElement(Long.class); vec.addElement(Time.class); vec.addElement(long.class); vec.addElement(Character[].class); vec.addElement(char[].class); return vec; } protected Vector buildFromByteObjectArraryVec() { Vector vec = new Vector(); vec.addElement(Blob.class); vec.addElement(byte[].class); return vec; } protected Vector buildFromCharArrayVec() { Vector vec = new Vector(); vec.addElement(Clob.class); return vec; } protected Vector buildFromCharacterArrayVec() { Vector vec = new Vector(); vec.addElement(Clob.class); return vec; } protected void buildDataTypesConvertedToAClass() { dataTypesConvertedToAClass.put(BigDecimal.class, buildToBigDecimalVec()); dataTypesConvertedToAClass.put(BigInteger.class, buildToBigIntegerVec()); dataTypesConvertedToAClass.put(Boolean.class, buildToBooleanVec()); dataTypesConvertedToAClass.put(Byte.class, buildToByteVec()); dataTypesConvertedToAClass.put(byte[].class, buildToByteArrayVec()); dataTypesConvertedToAClass.put(Byte[].class, buildToByteObjectArrayVec()); dataTypesConvertedToAClass.put(Calendar.class, buildToCalendarVec()); dataTypesConvertedToAClass.put(Character.class, buildToCharacterVec()); dataTypesConvertedToAClass.put(Character[].class, buildToCharacterArrayVec()); dataTypesConvertedToAClass.put(char[].class, buildToCharArrayVec()); dataTypesConvertedToAClass.put(java.sql.Date.class, buildToDateVec()); dataTypesConvertedToAClass.put(Double.class, buildToDoubleVec()); dataTypesConvertedToAClass.put(Float.class, buildToFloatVec()); dataTypesConvertedToAClass.put(Integer.class, buildToIntegerVec()); dataTypesConvertedToAClass.put(Long.class, buildToLongVec()); dataTypesConvertedToAClass.put(Number.class, buildToNumberVec()); dataTypesConvertedToAClass.put(Short.class, buildToShortVec()); dataTypesConvertedToAClass.put(String.class, buildToStringVec()); dataTypesConvertedToAClass.put(Timestamp.class, buildToTimestampVec()); dataTypesConvertedToAClass.put(Time.class, buildToTimeVec()); dataTypesConvertedToAClass.put(java.util.Date.class, buildToUtilDateVec()); dataTypesConvertedToAClass.put(Clob.class, buildToClobVec()); dataTypesConvertedToAClass.put(Blob.class, buildToBlobVec()); } protected Vector buildAllTypesToAClassVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(Integer.class); vec.addElement(java.util.Date.class); vec.addElement(java.sql.Date.class); vec.addElement(Time.class); vec.addElement(Timestamp.class); vec.addElement(Calendar.class); vec.addElement(Character.class); vec.addElement(Double.class); vec.addElement(Float.class); vec.addElement(Long.class); vec.addElement(Short.class); vec.addElement(Byte.class); vec.addElement(BigInteger.class); vec.addElement(BigDecimal.class); vec.addElement(Number.class); vec.addElement(Boolean.class); vec.addElement(Character[].class); vec.addElement(Blob.class); vec.addElement(Clob.class); return vec; } protected Vector buildToBigDecimalVec() { Vector vec = buildNumberVec(); vec.addElement(String.class); return vec; } protected Vector buildToBigIntegerVec() { return buildToBigDecimalVec(); } protected Vector buildToBooleanVec() { Vector vec = buildToBigDecimalVec(); vec.addElement(Character.class); vec.addElement(Boolean.class); return vec; } protected Vector buildToByteVec() { return buildToBigDecimalVec(); } protected Vector buildToDoubleVec() { return buildToBigDecimalVec(); } protected Vector buildToFloatVec() { return buildToBigDecimalVec(); } protected Vector buildToIntegerVec() { Vector vec = buildToBigDecimalVec(); vec.addElement(Boolean.class); return vec; } protected Vector buildToLongVec() { Vector vec = buildToIntegerVec(); vec.addElement(Calendar.class); vec.addElement(java.util.Date.class); return vec; } protected Vector buildToNumberVec() { return buildToIntegerVec(); } protected Vector buildToShortVec() { return buildToIntegerVec(); } protected Vector buildToByteArrayVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(Blob.class); vec.addElement(byte[].class); vec.addElement(Byte[].class); return vec; } protected Vector buildToByteObjectArrayVec() { Vector vec = buildToByteArrayVec(); vec.addElement(Byte[].class); return vec; } protected Vector buildToCharacterVec() { Vector vec = buildToBigDecimalVec(); vec.addElement(Character.class); return vec; } protected Vector buildToCharacterArrayVec() { return buildAllTypesToAClassVec(); } protected Vector buildToCharArrayVec() { return buildAllTypesToAClassVec(); } protected Vector buildToStringVec() { return buildAllTypesToAClassVec(); } protected Vector buildToCalendarVec() { Vector vec = buildDateTimeVec(); vec.addElement(String.class); vec.addElement(Long.class); vec.addElement(java.sql.Date.class); vec.addElement(Time.class); return vec; } protected Vector buildToTimestampVec() { return buildToCalendarVec(); } protected Vector buildToUtilDateVec() { return buildToCalendarVec(); } protected Vector buildToDateVec() { Vector vec = buildDateTimeVec(); vec.addElement(String.class); vec.addElement(Long.class); vec.addElement(java.sql.Date.class); return vec; } protected Vector buildToTimeVec() { Vector vec = buildDateTimeVec(); vec.addElement(String.class); vec.addElement(Long.class); vec.addElement(Time.class); return vec; } protected Vector buildToBlobVec() { Vector vec = new Vector(); vec.addElement(Byte[].class); vec.addElement(byte[].class); return vec; } protected Vector buildToClobVec() { Vector vec = new Vector(); vec.addElement(String.class); vec.addElement(char[].class); vec.addElement(Character[].class); return vec; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy