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

oracle.toplink.essentials.exceptions.IntegrityChecker Maven / Gradle / Ivy

There is a newer version: 2.1-60f
Show newest version
/*
 * The contents of this file are subject to the terms 
 * of the Common Development and Distribution License 
 * (the "License").  You may not use this file except 
 * in compliance with the License.
 * 
 * You can obtain a copy of the license at 
 * glassfish/bootstrap/legal/CDDLv1.0.txt or 
 * https://glassfish.dev.java.net/public/CDDLv1.0.html. 
 * See the License for the specific language governing 
 * permissions and limitations under the License.
 * 
 * When distributing Covered Code, include this CDDL 
 * HEADER in each file and include the License file at 
 * glassfish/bootstrap/legal/CDDLv1.0.txt.  If applicable, 
 * add the following below this CDDL HEADER, with the 
 * fields enclosed by brackets "[]" replaced with your 
 * own identifying information: Portions Copyright [yyyy] 
 * [name of copyright owner]
 */
// Copyright (c) 1998, 2007, Oracle. All rights reserved.  
package oracle.toplink.essentials.exceptions;

import java.util.*;
import java.io.*;
import oracle.toplink.essentials.internal.helper.*;
import oracle.toplink.essentials.internal.sessions.AbstractRecord;
import oracle.toplink.essentials.internal.sessions.AbstractSession;

/**
 *    

Purpose: IntegrityChecker is used for catching all the descriptor exceptions, * and checking database tables. It gives the user options if he/she wants to * catch descriptor exceptions, check database, and check InstantiationPolicy or not. */ public class IntegrityChecker implements Serializable { /** To add all the Descriptor exceptions */ protected Vector caughtExceptions = null; /** To load the tables from database */ protected Vector tables = null; /** To know that should we catch all the descriptors exceptions or not */ protected boolean shouldCatchExceptions; /** To know that should we check database tables or not */ protected boolean shouldCheckDatabase; /** To know that should we check InstantiationPolicy or not */ protected boolean shouldCheckInstantiationPolicy; /** * PUBLIC: * IntegrityChecker is used for catching all the Descriptor Exceptions, * and check database tables. IntegrityChecker gives the option to the user that does he wants to * catch all the descriptor exceptions,check database, and check InstantiationPolicy or not. */ public IntegrityChecker() { super(); this.shouldCatchExceptions = true; this.shouldCheckDatabase = false; this.shouldCheckInstantiationPolicy = true; } /** * PUBLIC: * This method is used for catching all the Descriptor Exceptions */ public void catchExceptions() { setShouldCatchExceptions(true); } /** * PUBLIC: * This method is used to check the database tables. */ public void checkDatabase() { setShouldCheckDatabase(true); } /** * PUBLIC: * This method is used to check the InstantiationPolicy. */ public void checkInstantiationPolicy() { setShouldCheckInstantiationPolicy(true); } /** * INTERNAL: * This method checks that tables are present in the database. */ public boolean checkTable(DatabaseTable table, AbstractSession session) { if (getTables().size() == 0) { // load the tables from the session initializeTables(session); } //MySQL converts all the table names to lower case. if (session.getPlatform().isMySQL()) { return getTables().contains(table.getName().toLowerCase()); } return getTables().contains(table.getName()); } /** * PUBLIC: * This method is used for don't catching all the Descriptor Exceptions */ public void dontCatchExceptions() { setShouldCatchExceptions(false); } /** * PUBLIC: * This method is used for don't checking the database tables and fields. */ public void dontCheckDatabase() { setShouldCheckDatabase(false); } /** * PUBLIC: * This method is used for don't checking the InstantiationPolicy. */ public void dontCheckInstantiationPolicy() { setShouldCheckInstantiationPolicy(false); } /** * PUBLIC: * This method returns the vecotr which adds all the Descriptors Exceptions. */ public Vector getCaughtExceptions() { if (caughtExceptions == null) { caughtExceptions = new Vector(); } return caughtExceptions; } /** * INTERNAL: * This method returns a vector which holds all the tables of database */ public Vector getTables() { if (tables == null) { tables = new Vector(); } return tables; } /** * INTERNAL: * This method handle all the Descriptor Exceptions. * This method throw the exception or add the exceptions into a vector depand on the value of shouldCatchExceptions. */ public void handleError(RuntimeException runtimeException) { if (!shouldCatchExceptions()) { throw runtimeException; } getCaughtExceptions().addElement(runtimeException); } /** * INTERNAL: * Return if any errors occured. */ public boolean hasErrors() { if ((caughtExceptions != null) && (caughtExceptions.size() > 0)) { return true; } return false; } /** * INTERNAL: * Return if any runtime errors occured. */ public boolean hasRuntimeExceptions() { if (hasErrors()) { for (Enumeration exceptionsEnum = getCaughtExceptions().elements(); exceptionsEnum.hasMoreElements();) { if (exceptionsEnum.nextElement() instanceof RuntimeException) { return true; } } } return false; } /** * INTERNAL: * This method is used to get all the database tables and add them into a vector. */ public void initializeTables(AbstractSession session) { Vector result = session.getAccessor().getTableInfo(null, null, null, null, session); for (Enumeration resultEnum = result.elements(); resultEnum.hasMoreElements();) { AbstractRecord row = (AbstractRecord)resultEnum.nextElement(); tables.addElement(row.get("TABLE_NAME")); } } /** * INTERNAL: */ public void setCaughtExceptions(Vector exceptions) { this.caughtExceptions = exceptions; } /** * PUBLIC: * This method assigns the value to the variable (shouldCatchExceptions) * that we should catch all Descriptor Exceptions or not. */ public void setShouldCatchExceptions(boolean answer) { shouldCatchExceptions = answer; } /** * PUBLIC: * This method assigns the value to the variable (shouldCheckDatabase) * that we should check database or not. */ public void setShouldCheckDatabase(boolean answer) { shouldCheckDatabase = answer; } /** * PUBLIC: * This method assigns the value to the variable (shouldCheckInstantiationPolicy) * that we should check InstantiationPolicy or not. */ public void setShouldCheckInstantiationPolicy(boolean answer) { shouldCheckInstantiationPolicy = answer; } /** * PUBLIC: * This method is used to know that all the Descriptor Exceptions should be thrown or not. */ public boolean shouldCatchExceptions() { return shouldCatchExceptions; } /** * PUBLIC: * This method is used to know that database tables and fields should be checked or not. */ public boolean shouldCheckDatabase() { return shouldCheckDatabase; } /** * PUBLIC: * This method tells us that we should check InstantiationPolicy or not. */ public boolean shouldCheckInstantiationPolicy() { return shouldCheckInstantiationPolicy; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy