
jodd.joy.core.DefaultWebApplication Maven / Gradle / Ivy
Show all versions of jodd-joy Show documentation
// Copyright (c) 2003-present, Jodd Team (http://jodd.org)
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// 2. Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
package jodd.joy.core;
import jodd.madvoc.proxetta.ProxettaAwareActionsManager;
import jodd.madvoc.component.MadvocConfig;
import jodd.madvoc.config.AutomagicMadvocConfigurator;
import jodd.madvoc.config.MadvocConfigurator;
import jodd.madvoc.petite.PetiteWebApplication;
import jodd.petite.PetiteContainer;
/**
* Default web application.
*/
public abstract class DefaultWebApplication extends PetiteWebApplication {
protected final DefaultAppCore defaultAppCore;
protected DefaultWebApplication() {
defaultAppCore = createAppCore();
}
/**
* Creates {@link DefaultAppCore}.
*/
protected abstract DefaultAppCore createAppCore();
/**
* Starts {@link DefaultAppCore application core} before web application is initialized.
*/
@Override
protected void initWebApplication() {
defaultAppCore.start();
super.initWebApplication();
}
/**
* Registers default and additional {@link ProxettaAwareActionsManager}.
* Because the custom action manager is registered using an instance,
* all custom Madvoc components should be registered before it!
* For that reason, custom madvoc components should be registered
* using {@link #registerCustomMadvocComponents()}.
*/
@Override
public final void registerMadvocComponents() {
super.registerMadvocComponents();
registerCustomMadvocComponents();
registerComponent(new ProxettaAwareActionsManager(defaultAppCore.getProxetta()));
}
/**
* Registers custom madvoc components.
* @see #registerMadvocComponents()
*/
protected void registerCustomMadvocComponents() {
}
/**
* Defines application container for Madvoc usage. We share applications
* Petite container from the appCore, so Madvoc can use it when creating
* Madvoc actions. By sharing the application container with the Madvoc,
* Petite beans can be injected in the actions.
*
* If container is not shared, PetiteWebApplication would create
* new Petite container; that is fine when e.g. there are no layers.
*/
@Override
protected PetiteContainer providePetiteContainer() {
return defaultAppCore.getPetite();
}
/**
* Configures AutomagicMadvocConfigurator
.
*/
@Override
public void configure(MadvocConfigurator configurator) {
if (configurator instanceof AutomagicMadvocConfigurator) {
AutomagicMadvocConfigurator madvocConfigurator = (AutomagicMadvocConfigurator) configurator;
defaultAppCore.getAppScanner().configure(madvocConfigurator);
}
super.configure(configurator);
}
/**
* Destroys application context and Madvoc.
*/
@Override
protected void destroy(MadvocConfig madvocConfig) {
defaultAppCore.stop();
super.destroy(madvocConfig);
}
}