/*******************************************************************************
* Copyright (c) 2014, 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:
* Iaroslav Savytskyi - August 13/2014 - 2.6.0 - Initial implementation
******************************************************************************/
package org.eclipse.persistence.testing.sdo.server;
import org.eclipse.persistence.sdo.helper.SDOHelperContext;
import javax.annotation.PostConstruct;
import javax.ejb.Singleton;
import javax.ejb.Startup;
import java.net.URL;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* Context startup listener.
*
* Responsible for the initialization process.
*/
@Singleton
@Startup
public class InitSingleton {
private static final Logger LOGGER = Logger.getLogger(InitSingleton.class.getName());
@PostConstruct
public void init() {
LOGGER.info("\n********** init() called **********\n");
try {
ClassLoader cl = Thread.currentThread().getContextClassLoader();
URL url = cl.getResource("org/eclipse/persistence/testing/sdo/server/Dept.xsd");
String path = url.toExternalForm();
SDOHelperContext.getHelperContext().getXSDHelper().define(url.openStream(), path.substring(0, path.lastIndexOf('/') + 1));
LOGGER.info("\n********** initialized **********\n");
} catch (Exception e) {
if (LOGGER.isLoggable(Level.INFO)) {
LOGGER.info("init() failed with error: " + e.getMessage());
}
e.printStackTrace();
throw new DeptServiceInitException(e);
}
}
}