blob: 489fc8949820d90beaaeecabfe896a8ab7bd3e93 [file] [log] [blame]
/*
* Copyright (c) 2010, 2018 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 v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package com.sun.enterprise.glassfish.bootstrap;
import com.sun.enterprise.module.bootstrap.ModuleStartup;
import org.glassfish.embeddable.CommandRunner;
import org.glassfish.embeddable.Deployer;
import org.glassfish.embeddable.GlassFish;
import org.glassfish.embeddable.GlassFishException;
import org.glassfish.hk2.api.ServiceLocator;
import java.util.Properties;
/**
* @author Sanjeeb.Sahoo@Sun.COM
*/
public class GlassFishImpl implements GlassFish {
private ModuleStartup gfKernel;
private ServiceLocator habitat;
volatile Status status = Status.INIT;
public GlassFishImpl(ModuleStartup gfKernel, ServiceLocator habitat, Properties gfProps) throws GlassFishException {
this.gfKernel = gfKernel;
this.habitat = habitat;
configure(gfProps);
}
private void configure(Properties gfProps) throws GlassFishException {
// If there are custom configurations like http.port, https.port, jmx.port then configure them.
Configurator configurator = new ConfiguratorImpl(habitat);
configurator.configure(gfProps);
}
public synchronized void start() throws GlassFishException {
if (status == Status.STARTED || status == Status.STARTING || status == Status.DISPOSED) {
throw new IllegalStateException("Already in " + status + " state.");
}
status = Status.STARTING;
gfKernel.start();
status = Status.STARTED;
}
public synchronized void stop() throws GlassFishException {
if (status == Status.STOPPED || status == Status.STOPPING || status == Status.DISPOSED) {
throw new IllegalStateException("Already in " + status + " state.");
}
status = Status.STOPPING;
gfKernel.stop();
status = Status.STOPPED;
}
public synchronized void dispose() throws GlassFishException {
if (status == Status.DISPOSED) {
throw new IllegalStateException("Already disposed.");
} else if (status != Status.STOPPED) {
try {
stop();
} catch (Exception e) {
// ignore and continue.
e.printStackTrace();
}
}
this.gfKernel = null;
this.habitat = null;
this.status = Status.DISPOSED;
}
public Status getStatus() {
return status;
}
public <T> T getService(Class<T> serviceType) throws GlassFishException {
return getService(serviceType, null);
}
public synchronized <T> T getService(Class<T> serviceType, String serviceName) throws GlassFishException {
if (status != Status.STARTED) {
throw new IllegalArgumentException("Server is not started yet. It is in " + status + "state");
}
return serviceName != null ? habitat.<T>getService(serviceType, serviceName) :
habitat.<T>getService(serviceType);
}
public Deployer getDeployer() throws GlassFishException {
return getService(Deployer.class);
}
public CommandRunner getCommandRunner() throws GlassFishException {
return getService(CommandRunner.class);
}
}