All Downloads are FREE. Search and download functionalities are using the official Maven repository.

play.api.Play.scala Maven / Gradle / Ivy

/*
 * Copyright (C) 2009-2016 Lightbend Inc. 
 */
package play.api

import akka.stream.Materializer
import play.utils.Threads

import java.io._

import scala.concurrent.Await
import scala.concurrent.duration.Duration
import scala.util.control.NonFatal
import javax.xml.parsers.SAXParserFactory
import org.apache.xerces.impl.Constants
import javax.xml.XMLConstants

/** Application mode, either `DEV`, `TEST`, or `PROD`. */
object Mode extends Enumeration {
  type Mode = Value
  val Dev, Test, Prod = Value
}

/**
 * @see compare-to-play.md
 *
 * High-level API to access Play global features.
 *
 * Note that this API depends on a running application.
 * You can import the currently running application in a scope using:
 * {{{
 * import play.api.Play.current
 * }}}
 */
object Play {

  private val logger = Logger(Play.getClass)

  /*
   * We want control over the sax parser used so we specify the factory required explicitly. We know that
   * SAXParserFactoryImpl will yield a SAXParser having looked at its source code, despite there being
   * no explicit doco stating this is the case. That said, there does not appear to be any other way than
   * declaring a factory in order to yield a parser of a specific type.
   */
  private[play] val xercesSaxParserFactory =
    SAXParserFactory.newInstance("org.apache.xerces.jaxp.SAXParserFactoryImpl", Play.getClass.getClassLoader)
  xercesSaxParserFactory.setFeature(Constants.SAX_FEATURE_PREFIX + Constants.EXTERNAL_GENERAL_ENTITIES_FEATURE, false)
  xercesSaxParserFactory.setFeature(Constants.SAX_FEATURE_PREFIX + Constants.EXTERNAL_PARAMETER_ENTITIES_FEATURE, false)
  xercesSaxParserFactory.setFeature(Constants.XERCES_FEATURE_PREFIX + Constants.DISALLOW_DOCTYPE_DECL_FEATURE, true)
  xercesSaxParserFactory.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true)

  /*
   * A parser to be used that is configured to ensure that no schemas are loaded.
   */
  private[play] def XML = scala.xml.XML.withSAXParser(xercesSaxParserFactory.newSAXParser())

  /**
   * Returns the currently running application, or `null` if not defined.
   *
   * @deprecated This is a static reference to application, use DI, since 2.5.0
   */
  @deprecated("This is a static reference to application, use DI", "2.5.0")
  def unsafeApplication: Application = _currentApp

  /**
   * Optionally returns the current running application.
   *
   * @deprecated This is a static reference to application, use DI, since 2.5.0
   */
  @deprecated("This is a static reference to application, use DI instead", "2.5.0")
  def maybeApplication: Option[Application] = Option(_currentApp)

  private[play] def privateMaybeApplication: Option[Application] = Option(_currentApp)

  /* Used by the routes compiler to resolve an application for the injector.  Treat as private. */
  def routesCompilerMaybeApplication: Option[Application] = Option(_currentApp)

  /**
   * Implicitly import the current running application in the context.
   *
   * Note that by relying on this, your code will only work properly in
   * the context of a running application.
   *
   * @deprecated This is a static reference to application, use DI, since 2.5.0
   */
  @deprecated("This is a static reference to application, use DI instead", "2.5.0")
  implicit def current: Application = privateMaybeApplication.getOrElse(sys.error("There is no started application"))

  @volatile private[play] var _currentApp: Application = _

  /**
   * Starts this application.
   *
   * @param app the application to start
   */
  def start(app: Application) {

    // First stop previous app if exists
    stop(_currentApp)

    _currentApp = app

    //@giabao: commented out global.beforeStart / onStart, routes initialize.
    // In standalone version, we have removed app.routes & app.global

    app.mode match {
      case Mode.Test =>
      case mode => logger.info("Application started (" + mode + ")")
    }

  }

  /**
   * Stops the given application.
   */
  def stop(app: Application) {
    if (app != null) {
      Threads.withContextClassLoader(app.classloader) {
        //app.global.onStop(app) @giabao
        try { Await.ready(app.stop(), Duration.Inf) } catch { case NonFatal(e) => logger.warn("Error stopping application", e) }
      }
    }
    _currentApp = null
  }

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def resourceAsStream(name: String)(implicit app: Application): Option[InputStream] = {
    app.resourceAsStream(name)
  }

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def resource(name: String)(implicit app: Application): Option[java.net.URL] = {
    app.resource(name)
  }

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def getFile(relativePath: String)(implicit app: Application): File = {
    app.getFile(relativePath)
  }

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def getExistingFile(relativePath: String)(implicit app: Application): Option[File] = {
    app.getExistingFile(relativePath)
  }

  /**
   * @deprecated inject the [[play.api.Application]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def application(implicit app: Application): Application = app

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def classloader(implicit app: Application): ClassLoader = app.classloader

  /**
   * @deprecated inject the [[play.api.Configuration]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def configuration(implicit app: Application): Configuration = app.configuration

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def mode(implicit app: Application): Mode.Mode = app.mode

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def isDev(implicit app: Application): Boolean = (app.mode == Mode.Dev)

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def isProd(implicit app: Application): Boolean = (app.mode == Mode.Prod)

  /**
   * @deprecated inject the [[play.api.Environment]] instead
   */
  @deprecated("inject the play.api.Environment instead", "2.5.0")
  def isTest(implicit app: Application): Boolean = (app.mode == Mode.Test)


  /**
   * A convenient function for getting an implicit materializer from the current application
   */
  implicit def materializer(implicit app: Application): Materializer = app.materializer
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy