play.api.inject

Module

abstract class Module extends AnyRef

A Play dependency injection module.

Dependency injection modules can be used by Play plugins to provide bindings for JSR-330 compliant ApplicationLoaders. Any plugin that wants to provide components that a Play application can use may implement one of these.

Providing custom modules can be done by creating a resource on the classpath called play.modules. This file is expected to contain a list of module classes, one class per line. For example:

com.example.FooModule
com.example.BarModule

It is strongly advised that in addition to providing a module for JSR-330 DI, that plugins also provide a Scala trait that constructs the modules manually. This allows for use of the module without needing a runtime dependency injection provider.

The bind methods are provided only as a DSL for specifying bindings. For example:

def bindings(env: Environment, conf: Configuration) = Seq(
bind[Foo].to[FooImpl],
bind[Bar].to(new Bar()),
bind[Foo].qualifiedWith[SomeQualifier].to[OtherFoo]
)
Source
Module.scala
Linear Supertypes
AnyRef, Any
Known Subclasses
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. Module
  2. AnyRef
  3. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Module()

Abstract Value Members

  1. abstract def bindings(environment: Environment, configuration: Configuration): Seq[Binding[_]]

    Get the bindings provided by this module.

    Get the bindings provided by this module.

    Implementations are strongly encouraged to do *nothing* in this method other than provide bindings. Startup should be handled in the the constructors and/or providers bound in the returned bindings. Dependencies on other modules or components should be expressed through constructor arguments.

    The configuration and environment a provided for the purpose of producing dynamic bindings, for example, if what gets bound depends on some configuration, this may be read to control that.

    environment

    The environment

    configuration

    The configuration

    returns

    A sequence of bindings

Concrete Value Members

  1. final def !=(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  5. final def bind[T](implicit arg0: ClassTag[T]): BindingKey[T]

    Create a binding key for the given class.

  6. final def bind[T](clazz: Class[T]): BindingKey[T]

    Create a binding key for the given class.

  7. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  9. def equals(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  10. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  11. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  12. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  13. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  15. final def notify(): Unit

    Definition Classes
    AnyRef
  16. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  17. final def seq(bindings: Binding[_]*): Seq[Binding[_]]

    Create a seq.

    Create a seq.

    For Java compatibility.

    Annotations
    @varargs()
  18. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  19. def toString(): String

    Definition Classes
    AnyRef → Any
  20. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  22. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped