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

org.dbflute.s2dao.extension.TnSqlLogRegistry Maven / Gradle / Ivy

/*
 * Copyright 2014-2015 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied. See the License for the specific language
 * governing permissions and limitations under the License.
 */
package org.dbflute.s2dao.extension;

import java.lang.reflect.Constructor;
import java.lang.reflect.Method;

/**
 * @author jflute
 */
public class TnSqlLogRegistry {

    // ===================================================================================
    //                                                                          Definition
    //                                                                          ==========
    protected static final String PKG_ORG_SEASAR = "org.seasar.";
    protected static final String NAME_SqlLogRegistryLocator = PKG_ORG_SEASAR + "extension.jdbc.SqlLogRegistryLocator";
    protected static final String NAME_getInstance = "getInstance";
    protected static final String NAME_setInstance = "setInstance";
    protected static final String NAME_SqlLogRegistry = PKG_ORG_SEASAR + "extension.jdbc.SqlLogRegistry";
    protected static final String NAME_SqlLogRegistryImpl = PKG_ORG_SEASAR + "extension.jdbc.impl.SqlLogRegistryImpl";
    protected static final String NAME_SqlLog = PKG_ORG_SEASAR + "extension.jdbc.SqlLog";
    protected static final String NAME_SqlLogImpl = PKG_ORG_SEASAR + "extension.jdbc.impl.SqlLogImpl";
    protected static final boolean exists;
    protected static final Class locatorType;
    protected static final Method locatorInstanceMethod;
    protected static final Class registryType;
    protected static final Class registryImplType;
    protected static final Class sqlLogType;
    protected static final Class sqlLogImplType;
    static {
        locatorType = forNameContainerSqlLogRegistryLocator();
        if (locatorType != null) {
            exists = true;
            final String methodName = NAME_getInstance;
            final Method foundMethod;
            try {
                foundMethod = locatorType.getMethod(methodName, (Class[]) null);
            } catch (Exception e) {
                String msg = "Failed to get the method to get the instance: " + methodName;
                throw new IllegalStateException(msg);
            }
            locatorInstanceMethod = foundMethod;
            registryType = forNameContainerSqlLogRegistry();
            registryImplType = forNameContainerSqlLogRegistryImpl();
            sqlLogType = forNameContainerSqlLog();
            sqlLogImplType = forNameContainerSqlLogImpl();
        } else {
            exists = false;
            locatorInstanceMethod = null;
            registryType = null;
            registryImplType = null;
            sqlLogType = null;
            sqlLogImplType = null;
        }
    }

    // ===================================================================================
    //                                                                        Public Entry
    //                                                                        ============
    public static boolean exists() {
        return exists;
    }

    public static boolean setupSqlLogRegistry() {
        if (!exists) {
            return false;
        }
        final Object sqlLogRegistryImpl = createContainerSqlLogRegistryImpl();
        final String methodName = NAME_setInstance;
        try {
            final Method method = locatorType.getMethod(methodName, new Class[] { registryType });
            method.invoke(null, new Object[] { sqlLogRegistryImpl });
            return true;
        } catch (Exception e) {
            String msg = "Failed to set the locator instance:";
            msg = msg + " locatorType=" + locatorType;
            msg = msg + " methodName=" + methodName;
            throw new IllegalStateException(msg, e);
        }
    }

    public static void clearSqlLogRegistry() {
        if (!exists) {
            return;
        }
        final String methodName = "clear";
        try {
            final Object sqlLogRegistry = findContainerSqlLogRegistry();
            final Method method = locatorType.getMethod(methodName, new Class[] {});
            method.invoke(sqlLogRegistry, new Object[] {});
        } catch (Exception e) {
            String msg = "Failed to clear registry of the locator:";
            msg = msg + " locatorType=" + locatorType;
            msg = msg + " methodName=" + methodName;
            throw new IllegalStateException(msg, e);
        }
    }

    public static Object findContainerSqlLogRegistry() {
        if (!exists) {
            return null;
        }
        try {
            return locatorInstanceMethod.invoke(null, (Object[]) null);
        } catch (Exception e) {
            String msg = "Failed to get the locator instance:";
            msg = msg + " locatorType=" + locatorType;
            msg = msg + " methodName=" + NAME_getInstance;
            throw new IllegalStateException(msg, e);
        }
    }

    public static void closeRegistration() {
        if (!exists) {
            return;
        }
        final String methodName = NAME_setInstance;
        try {
            final Method method = locatorType.getMethod(methodName, new Class[] { registryType });
            method.invoke(null, new Object[] { null });
        } catch (Exception e) {
            String msg = "Failed to handle the locator method:";
            msg = msg + " locatorType=" + locatorType;
            msg = msg + " methodName=" + methodName;
            throw new IllegalStateException(msg, e);
        }
    }

    public static void push(String rawSql, String completeSql, Object[] bindArgs, Class[] bindArgTypes, Object sqlLogRegistry) {
        if (!exists) {
            return;
        }
        if (sqlLogRegistry == null) {
            throw new IllegalArgumentException("sqlLogRegistry should not be null.");
        }
        final Object sqlLogImpl = createContainerSqlLogImpl(rawSql, completeSql, bindArgs, bindArgTypes);
        reflectSqlLogToContainerSqlLogRegistry(sqlLogImpl, sqlLogRegistry);
    }

    public static String peekCompleteSql() {
        if (!exists) {
            return null;
        }
        final Object sqlLogRegistry = findContainerSqlLogRegistry();
        final Object sqlLog = findLastContainerSqlLog(sqlLogRegistry);
        return extractCompleteSqlFromContainerSqlLog(sqlLog);
    }

    // ===================================================================================
    //                                                                Container Reflection
    //                                                                ====================
    protected static Object createContainerSqlLogRegistryImpl() {
        try {
            final Constructor constructor = registryImplType.getConstructor(int.class);
            return constructor.newInstance(new Object[] { 3 });
        } catch (Exception e) {
            String msg = "Failed to create registryImpl:";
            msg = msg + " registryImplType=" + registryImplType;
            throw new IllegalStateException(msg, e);
        }
    }

    protected static Object createContainerSqlLogImpl(String rawSql, String completeSql, Object[] bindArgs, Class[] bindArgTypes) {
        try {
            final Class[] argTypes = new Class[] { String.class, String.class, Object[].class, Class[].class };
            final Constructor constructor = sqlLogImplType.getConstructor(argTypes);
            return constructor.newInstance(new Object[] { rawSql, completeSql, bindArgs, bindArgTypes });
        } catch (Exception e) {
            String msg = "Failed to create sqlLogImpl:";
            msg = msg + " completeSql=" + completeSql;
            msg = msg + " sqlLogImplType=" + sqlLogImplType;
            throw new IllegalStateException(msg, e);
        }
    }

    protected static void reflectSqlLogToContainerSqlLogRegistry(Object sqlLog, Object sqlLogRegistry) {
        if (sqlLog == null || sqlLogRegistry == null) {
            return;
        }
        final String methodName = "add";
        try {
            final Method method = registryType.getMethod(methodName, new Class[] { sqlLogType });
            method.invoke(sqlLogRegistry, new Object[] { sqlLog });
        } catch (Exception e) {
            String msg = "Failed to reflect sqlLogRegistry:";
            msg = msg + " sqlLog=" + sqlLog + " sqlLogRegistry=" + sqlLogRegistry;
            msg = msg + " registryType=" + registryType;
            msg = msg + " methodName=" + methodName;
            throw new IllegalStateException(msg, e);
        }
    }

    protected static Object findLastContainerSqlLog(Object sqlLogRegistry) {
        if (sqlLogRegistry == null) {
            return null;
        }
        final String methodName = "getLast";
        try {
            final Method method = registryType.getMethod(methodName, (Class[]) null);
            return method.invoke(sqlLogRegistry, (Object[]) null);
        } catch (Exception e) {
            String msg = "Failed to find sqlLog:";
            msg = msg + " sqlLogRegistry=" + sqlLogRegistry;
            msg = msg + " methodName=" + methodName;
            throw new IllegalStateException(msg, e);
        }
    }

    protected static String extractCompleteSqlFromContainerSqlLog(Object sqlLog) {
        if (sqlLog == null) {
            return null;
        }
        final String methodName = "getCompleteSql";
        try {
            final Method method = sqlLogType.getMethod(methodName, (Class[]) null);
            return (String) method.invoke(sqlLog, (Object[]) null);
        } catch (Exception e) {
            String msg = "Failed to extract completeSql:";
            msg = msg + " sqlLog=" + sqlLog;
            msg = msg + " methodName=" + methodName;
            throw new IllegalStateException(msg, e);
        }
    }

    protected static Class forNameContainerSqlLogRegistryLocator() {
        Class clazz = null;
        try {
            clazz = Class.forName(NAME_SqlLogRegistryLocator);
        } catch (Exception ignored) {
            return null;
        }
        return clazz;
    }

    protected static Class forNameContainerSqlLogRegistry() {
        Class clazz = null;
        try {
            clazz = Class.forName(NAME_SqlLogRegistry);
        } catch (Exception ignored) {
            return null;
        }
        return clazz;
    }

    protected static Class forNameContainerSqlLogRegistryImpl() {
        Class clazz = null;
        try {
            clazz = Class.forName(NAME_SqlLogRegistryImpl);
        } catch (Exception ignored) {
            return null;
        }
        return clazz;
    }

    protected static Class forNameContainerSqlLog() {
        Class clazz = null;
        try {
            clazz = Class.forName(NAME_SqlLog);
        } catch (Exception ignored) {
            return null;
        }
        return clazz;
    }

    protected static Class forNameContainerSqlLogImpl() {
        Class clazz = null;
        try {
            clazz = Class.forName(NAME_SqlLogImpl);
        } catch (Exception ignored) {
            return null;
        }
        return clazz;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy