|
Jetty example source code file (Jetty6RunMojo.java)
The Jetty Jetty6RunMojo.java source code//======================================================================== //$Id: Jetty6RunMojo.java 2299 2008-01-03 23:40:50Z janb $ //Copyright 2000-2004 Mort Bay Consulting Pty. Ltd. //------------------------------------------------------------------------ //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.mortbay.jetty.plugin; import java.io.File; import org.apache.maven.plugin.MojoExecutionException; import org.apache.maven.plugin.MojoFailureException; import org.mortbay.jetty.Connector; import org.mortbay.jetty.Handler; import org.mortbay.jetty.RequestLog; import org.mortbay.jetty.Server; import org.mortbay.jetty.handler.ContextHandler; import org.mortbay.jetty.handler.ContextHandlerCollection; import org.mortbay.jetty.handler.HandlerCollection; import org.mortbay.jetty.plugin.util.JettyPluginServer; import org.mortbay.jetty.security.UserRealm; import org.mortbay.xml.XmlConfiguration; /** * <p> * This goal is used in-situ on a Maven project without first requiring that the project * is assembled into a war, saving time during the development cycle. * The plugin forks a parallel lifecycle to ensure that the "compile" phase has been completed before invoking Jetty. This means * that you do not need to explicity execute a "mvn compile" first. It also means that a "mvn clean jetty:run" will ensure that * a full fresh compile is done before invoking Jetty. * </p> * <p> * Once invoked, the plugin can be configured to run continuously, scanning for changes in the project and automatically performing a * hot redeploy when necessary. This allows the developer to concentrate on coding changes to the project using their IDE of choice and have those changes * immediately and transparently reflected in the running web container, eliminating development time that is wasted on rebuilding, reassembling and redeploying. * </p> * <p> * You may also specify the location of a jetty.xml file whose contents will be applied before any plugin configuration. * This can be used, for example, to deploy a static webapp that is not part of your maven build. * </p> * <p> * There is a <a href="run-mojo.html">reference guide to the configuration parameters for this plugin, and more detailed information * with examples in the <a href="http://docs.codehaus.org/display/JETTY/Maven+Jetty+Plugin">Configuration Guide. * </p> * @author janb * * @goal run * @requiresDependencyResolution runtime * @execute phase="test-compile" * @description Runs jetty6 directly from a maven project */ public class Jetty6RunMojo extends AbstractJettyRunMojo { /** * List of connectors to use. If none are configured * then the default is a single SelectChannelConnector at port 8080. You can * override this default port number by using the system property jetty.port * on the command line, eg: mvn -Djetty.port=9999 jetty:run * * @parameter */ private Connector[] connectors; /** * List of other contexts to set up. Optional. * @parameter */ private ContextHandler[] contextHandlers; /** * List of security realms to set up. Optional. * @parameter */ private UserRealm[] userRealms; /** * A RequestLog implementation to use for the webapp at runtime. * Optional. * @parameter */ private RequestLog requestLog; public Object getConfiguredRequestLog() { return this.requestLog; } /** * * * @see org.mortbay.jetty.plugin.AbstractJettyRunMojo#getConfiguredConnectors() */ public Object[] getConfiguredConnectors() { return this.connectors; } /** * * * @see org.mortbay.jetty.plugin.AbstractJettyRunMojo#getConfiguredUserRealms() */ public Object[] getConfiguredUserRealms() { return this.userRealms; } /** * @return Returns the contextHandlers. */ public ContextHandler[] getConfiguredContextHandlers() { return this.contextHandlers; } /** * * * @see org.mortbay.jetty.plugin.AbstractJettyRunMojo#createServer() */ public JettyPluginServer createServer() { return new Jetty6PluginServer(); } public void finishConfigurationBeforeStart() throws Exception { Handler[] handlers = getConfiguredContextHandlers(); JettyPluginServer plugin=getServer(); Server server=(Server)plugin.getProxiedObject(); HandlerCollection contexts = (HandlerCollection)server.getChildHandlerByClass(ContextHandlerCollection.class); if (contexts==null) contexts = (HandlerCollection)server.getChildHandlerByClass(HandlerCollection.class); for (int i=0; (handlers != null) && (i < handlers.length); i++) { contexts.addHandler(handlers[i]); } } public void applyJettyXml() throws Exception { if (getJettyXmlFile() == null) return; getLog().info( "Configuring Jetty from xml configuration file = " + getJettyXmlFile() ); XmlConfiguration xmlConfiguration = new XmlConfiguration(getJettyXmlFile().toURL()); xmlConfiguration.configure(getServer().getProxiedObject()); } public void execute() throws MojoExecutionException, MojoFailureException { super.execute(); } } Other Jetty examples (source code examples)Here is a short list of links related to this Jetty Jetty6RunMojo.java source code file: |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2021 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.