Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

manual/working/scalaGuide/advanced/extending/ScalaPlugins.md #1265

Open
garbagetown opened this issue Feb 8, 2016 · 0 comments
Open

manual/working/scalaGuide/advanced/extending/ScalaPlugins.md #1265

garbagetown opened this issue Feb 8, 2016 · 0 comments
Milestone

Comments

@garbagetown
Copy link
Member

--- /Users/garbagetown/Desktop/2.2.0/manual/working/scalaGuide/advanced/extending/ScalaPlugins.md   2016-02-07 23:19:03.000000000 +0900
+++ //Users/garbagetown/Desktop/2.4.x/manual/working/scalaGuide/advanced/extending/ScalaPlugins.md  2016-02-07 23:19:30.000000000 +0900
@@ -1,25 +1,56 @@
+<!--- Copyright (C) 2009-2015 Typesafe Inc. <http://www.typesafe.com> -->
 # Writing Plugins

-Play comes with a few plugins predefined for all applications, these plugins are the following: 
+> __Note__: Plugins are deprecated. Instead, use [[Modules|Modules]].

-* `DBPlugin` -> providing a JDBC datasource
-* `EvolutionPlugin` -> provides migration  _(only available if db was configured)_
-* `EbeanPlugin` -> provides Ebean support _(only available if db was configured)_
-* `MessagesPlugin` - > provides i18n support
-* `BasicCachePlugin` -> provides in-memory caching
-* `GlobalPlugin` -> executes application's settings
+In the context of the Play runtime, a plugin is a class that is able to plug into the Play lifecycle, and also allows sharing components in a non static way in your application.

-However, one can easily add a new plugin to an application.
+Not every library that adds functionality to Play is or needs to be a plugin in this context - a library that provides a custom filter for example does not need to be a plugin.

-1. first step is to implement play.api.Plugin trait which has three methods: onStart, onStop and enabled - [for example](https://github.com/playframework/playframework/blob/master/framework/src/play-cache/src/main/scala/play/api/cache/Cache.scala))
-2. this plugin should be available in the application either through pulling in it from a maven repository and referencing it
-as an app dependency or the plugin code can be part of a play application
-3. you can use it directly like `app.plugin[MyPlugin].map(_.api.mymethod).getOrElse(throwMyerror)` (where `app` is  a reference to the current application which can be obtain by importing play.api.Play.current) however, it's recommended to wrap it for convenience (for example, see [this](https://github.com/playframework/playframework/blob/master/framework/src/play-cache/src/main/scala/play/api/cache/Cache.scala))
-4. in your app create a file: `conf/play.plugins` and add a reference to your plugin:
+Similarly, plugins don't necessarily imply that they are reusable between applications, it is often very useful to implement a plugin locally within an application, in order to hook into the Play lifecycle and share components in your code.

-    5000:com.example.MyPlugin
+## Implementing plugins

-The number represents the plugin loading order, by setting it to > 10000 we can make sure it's loaded after the global plugins.
+Implementing a plugin requires two steps.  The first is to implement the `play.api.Plugin` interface:

-_Tip: If you are a scala developer but you want to share your plugin with java developers, you will need make sure your API is wrapped for Java users (see [this](https://github.com/playframework/playframework/blob/master/framework/src/play-cache/src/main/scala/play/api/cache/Cache.scala) and [this](https://github.com/playframework/playframework/blob/master/framework/src/play-cache/src/main/java/play/cache/Cache.java) for an example)_
+@[my-plugin](code/ScalaPlugins.scala)

+The next step is to register this with Play.  This can be done by creating a file called `play.plugins` and placing it in the root of the classloader.  In a typical Play app, this means putting it in the `conf` folder:
+
+'''
+2000:plugins.MyPlugin
+'''
+
+Each line in the `play.plugins` file contains a number followed by the fully qualified name of the plugin to load.  The number is used to control lifecycle ordering, lower numbers will be started first and stopped last.  Multiple plugins can be declared in the one file, and any lines started with `#` are treated as comments.
+
+Choosing the right number for ordering for a plugin is important, it needs to fit in appropriate according to what other plugins it depends on.  The plugins that Play uses use the following ordering numbers:
+
+* *100* - Utilities that have no dependencies, such as the messages plugin
+* *200* - Database connection pools
+* *300-500* - Plugins that depend on the database, such as JPA, Ebean and evolutions
+* *600* - The Play cache plugin
+* *700* - The WS plugin
+* *1000* - The Akka plugin
+* *10000* - The Global plugin, which invokes the `Global.onStart` and `Global.onStop` methods.  This plugin is intended to execute last.
+
+## Accessing plugins
+
+Plugins can be accessed via the `plugin` method on `play.api.Application`:
+
+@[access-plugin](code/ScalaPlugins.scala)
+
+## Actor example
+
+A common use case for using plugins is to create and share actors around the application.  This can be done by implementing an actors plugin:
+
+@[actor-example](code/ScalaPlugins.scala)
+
+Note the `Actors` companion object methods that allow easy access to the `ActorRef` for each actor, instead of code having to use the plugins API directly.
+
+The plugin can then be registered in `play.plugins`:
+
+'''
+1100:actors.Actors
+'''
+
+The reason `1100` was chosen for the ordering was because this plugin depends on the Akka plugin, and so must start after that.

@garbagetown garbagetown added this to the 2.4.x milestone Feb 8, 2016
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants