Class WebInfConfiguration

java.lang.Object
org.eclipse.jetty.ee10.webapp.AbstractConfiguration
org.eclipse.jetty.ee10.webapp.WebInfConfiguration
All Implemented Interfaces:
Configuration

public class WebInfConfiguration extends AbstractConfiguration
  • Field Details

  • Constructor Details

  • Method Details

    • preConfigure

      public void preConfigure(WebAppContext context) throws Exception
      Description copied from interface: Configuration
      Set up for configuration.

      Typically this step discovers configuration resources. Calls to preConfigure may alter the Configurations configured on the WebAppContext, so long as configurations prior to this configuration are not altered.

      Specified by:
      preConfigure in interface Configuration
      Overrides:
      preConfigure in class AbstractConfiguration
      Parameters:
      context - The context to configure
      Throws:
      Exception - if unable to pre configure
    • configure

      public void configure(WebAppContext context) throws Exception
      Description copied from interface: Configuration
      Configure WebApp.

      Typically this step applies the discovered configuration resources to either the WebAppContext or the associated MetaData.

      Specified by:
      configure in interface Configuration
      Overrides:
      configure in class AbstractConfiguration
      Parameters:
      context - The context to configure
      Throws:
      Exception - if unable to configure
    • deconfigure

      public void deconfigure(WebAppContext context) throws Exception
      Description copied from interface: Configuration
      DeConfigure WebApp. This method is called to undo all configuration done. This is called to allow the context to work correctly over a stop/start cycle
      Specified by:
      deconfigure in interface Configuration
      Overrides:
      deconfigure in class AbstractConfiguration
      Parameters:
      context - The context to configure
      Throws:
      Exception - if unable to deconfigure
    • resolveTempDirectory

      public void resolveTempDirectory(WebAppContext context) throws Exception
      Get a temporary directory in which to unpack the war etc etc. The algorithm for determining this is to check these alternatives in the order shown:

      A. Try to use an explicit directory specifically for this webapp:

      1. Iff an explicit directory is set for this webapp, use it. Set delete on exit depends on value of persistTempDirectory.
      2. If "jakarta.servlet.context.tempdir" context attribute is set for this webapp && exists && writeable, then use it. Set delete on exit depends on value of persistTempDirectory.

      B. Create a directory based on global settings. The new directory will be called "Jetty-"+host+"-"+port+"__"+context+"-"+virtualhost+"-"+randomdigits+".dir" If the temporary directory is persistent, then the random digits are not added to the name. The Server.getTempDirectory() is used for the parent of a created temporary directory.

      Parameters:
      context - the context to resolve the temp directory from
      Throws:
      Exception - if unable to resolve the temp directory
    • makeTempDirectory

      @Deprecated(forRemoval=true, since="12.0.12") public void makeTempDirectory(File parent, WebAppContext context) throws Exception
      Deprecated, for removal: This API element is subject to removal in a future version.
      Throws:
      Exception
    • unpack

      public void unpack(WebAppContext context) throws IOException
      Throws:
      IOException
    • getCanonicalNameForWebAppTmpDir

      @Deprecated(forRemoval=true, since="12.0.12") public static String getCanonicalNameForWebAppTmpDir(WebAppContext context)
      Deprecated, for removal: This API element is subject to removal in a future version.
      this method is no longer used
      Create a canonical name for a webapp temp directory.

      The form of the name is:

      "jetty-"+host+"-"+port+"-"+resourceBase+"-_"+context+"-"+virtualhost+"-"+randomdigits+".dir"
      host and port uniquely identify the server context and virtual host uniquely identify the webapp randomdigits ensure every tmp directory is unique
      Parameters:
      context - the context to get the canonical name from
      Returns:
      the canonical name for the webapp temp directory
    • getResourceBaseName

      @Deprecated(forRemoval=true, since="12.0.12") protected static String getResourceBaseName(Resource resource)
      Deprecated, for removal: This API element is subject to removal in a future version.
      this method is no longer needed
      Parameters:
      resource - the Resource for which to extract a short name
      Returns:
      extract a short name for the resource