/******************************************************************************* * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 * which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * http://www.eclipse.org/org/documents/edl-v10.php. * * Contributors: * Oracle - initial impl ******************************************************************************/ package org.eclipse.persistence.tools.tuning; import java.util.Map; import org.eclipse.persistence.config.PersistenceUnitProperties; import org.eclipse.persistence.sessions.Session; /** * Configures the persistence unit for debugging. * This disables caching and several performance optimizations. * The purpose is to provide a simplified debugging and development configuration. */ public class SafeModeTuner implements SessionTuner { public SafeModeTuner() { } /** * Allow any JPA persistence unit properties to be configured, prior to deployment. */ public void tunePreDeploy(Map properties) { properties.put(PersistenceUnitProperties.WEAVING_INTERNAL, "false"); properties.put(PersistenceUnitProperties.WEAVING_CHANGE_TRACKING, "false"); properties.put(PersistenceUnitProperties.CACHE_SHARED_DEFAULT, "false"); properties.put(PersistenceUnitProperties.JDBC_BIND_PARAMETERS, "false"); properties.put(PersistenceUnitProperties.ORM_SCHEMA_VALIDATION, "true"); properties.put(PersistenceUnitProperties.TEMPORAL_MUTABLE, "true"); } /** * Allow any Session configuration to be tune after meta-data has been processed, but before connecting the session. */ public void tuneDeploy(Session session) { } /** * Allow any Session configuration to be tune after deploying and connecting the session. */ public void tunePostDeploy(Session session) { } }