docs: Revise plugin documentation

This commit is contained in:
Richard Hansen 2020-11-12 23:39:49 -05:00 committed by John McLear
parent cc8dbb07fd
commit 6c07229d38

View file

@ -1,13 +1,13 @@
# Plugins # Plugins
Etherpad allows you to extend its functionality with plugins. A plugin registers Etherpad allows you to extend its functionality with plugins. A plugin registers
hooks (functions) for certain events (thus certain features) in Etherpad-lite to hooks (functions) for certain events (thus certain features) in Etherpad to
execute its own functionality based on these events. execute its own functionality based on these events.
Publicly available plugins can be found in the npm registry (see Publicly available plugins can be found in the npm registry (see
<https://npmjs.org>). Etherpad-lite's naming convention for plugins is to prefix <https://npmjs.org>). Etherpad's naming convention for plugins is to prefix your
your plugins with `ep_`. So, e.g. it's `ep_flubberworms`. Thus you can install plugins with `ep_`. So, e.g. it's `ep_flubberworms`. Thus you can install
plugins from npm, using `npm install ep_flubberworm` in etherpad-lite's root plugins from npm, using `npm install ep_flubberworm` in Etherpad's root
directory. directory.
You can also browse to `http://yourEtherpadInstan.ce/admin/plugins`, which will You can also browse to `http://yourEtherpadInstan.ce/admin/plugins`, which will
@ -16,64 +16,96 @@ functionality to search through all available plugins.
## Folder structure ## Folder structure
A basic plugin usually has the following folder structure: Ideally a plugin has the following folder structure:
``` ```
ep_<plugin>/ ep_<plugin>/
| static/ ├ .github/
| templates/ │ └ workflows/
| locales/ │ └ npmpublish.yml ◄─ GitHub workflow to auto-publish on push
+ ep.json ├ static/
+ package.json │ ├ css/ ◄─ static .css files
│ ├ images/ ◄─ static image files
│ ├ js/
│ │ └ index.js ◄─ static client-side code
│ └ tests/
│ ├ backend/
│ │ └ specs/ ◄─ backend (server) tests
│ └ frontend/
│ └ specs/ ◄─ frontend (client) tests
├ templates/ ◄─ EJS templates (.html, .js, .css, etc.)
├ locales/
│ ├ en.json ◄─ English (US) strings
│ └ qqq.json ◄─ optional hints for translators
├ .travis.yml ◄─ Travis CI config
├ LICENSE
├ README.md
├ ep.json ◄─ Etherpad plugin definition
├ index.js ◄─ server-side code
├ package.json
└ package-lock.json
``` ```
If your plugin includes client-side hooks, put them in `static/js/`. If you're If your plugin includes client-side hooks, put them in `static/js/`. If you're
adding in CSS or image files, you should put those files in `static/css/ `and adding in CSS or image files, you should put those files in `static/css/ `and
`static/image/`, respectively, and templates go into `templates/`. Translations `static/image/`, respectively, and templates go into `templates/`. Translations
go into `locales/` go into `locales/`. Tests go in `static/tests/backend/specs/` and
`static/tests/frontend/specs/`.
A Standard directory structure like this makes it easier to navigate through A Standard directory structure like this makes it easier to navigate through
your code. That said, do note, that this is not actually *required* to make your your code. That said, do note, that this is not actually *required* to make your
plugin run. If you want to make use of our i18n system, you need to put your plugin run. If you want to make use of our i18n system, you need to put your
translations into `locales/`, though, in order to have them integrated. (See translations into `locales/`, though, in order to have them integrated. (See
"Localization" for more info on how to localize your plugin) "Localization" for more info on how to localize your plugin.)
## Plugin definition ## Plugin definition
Your plugin definition goes into `ep.json`. In this file you register your Your plugin definition goes into `ep.json`. In this file you register your hook
hooks, indicate the parts of your plugin and the order of execution. (A functions, indicate the parts of your plugin and the order of execution. (A
documentation of all available events to hook into can be found in chapter documentation of all available events to hook into can be found in chapter
[hooks](#all_hooks).) [hooks](#all_hooks).)
A hook registration is a pairs of a hook name and a function reference (filename
to require() + exported function name)
```json ```json
{ {
"parts": [ "parts": [
{ {
"name": "nameThisPartHoweverYouWant", "name": "nameThisPartHoweverYouWant",
"hooks": { "hooks": {
"authenticate" : "ep_<plugin>/<file>:FUNCTIONNAME1", "authenticate": "ep_<plugin>/<file>:functionName1",
"expressCreateServer": "ep_<plugin>/<file>:FUNCTIONNAME2" "expressCreateServer": "ep_<plugin>/<file>:functionName2"
}, },
"client_hooks": { "client_hooks": {
"acePopulateDOMLine": "ep_plugin/<file>:FUNCTIONNAME3" "acePopulateDOMLine": "ep_<plugin>/<file>:functionName3"
} }
} }
] ]
} }
``` ```
Etherpad-lite will expect the part of the hook definition before the colon to be A hook function registration maps a hook name to a hook function specification.
a javascript file and will try to require it. The part after the colon is The hook function specification looks like `ep_example/file.js:functionName`. It
expected to be a valid function identifier of that module. So, you have to consists of two parts separated by a colon: a module name to `require()` and the
export your hooks, using name of a function exported by the named module. See
[`module.exports`](https://nodejs.org/docs/latest/api/modules.html#modules_modules) [`module.exports`](https://nodejs.org/docs/latest/api/modules.html#modules_module_exports)
and register it in `ep.json` as `ep_<plugin>/path/to/<file>:FUNCTIONNAME`. You for how to export a function.
can omit the `FUNCTIONNAME` part, if the exported function has got the same name
as the hook. So `"authorize" : "ep_flubberworm/foo"` will call the function For the module name you can omit the `.js` suffix, and if the file is `index.js`
`exports.authorize` in `ep_flubberworm/foo.js` you can use just the directory name.
You can also omit the function name and separating colon. If you do, Etherpad
will look for an exported function whose name matches the name of the hook
(e.g., `authenticate`). You cannot omit the function name if the module name
contains a colon.
For example, all of the following will cause the `authorize` hook to call the
`exports.authorize` function in `index.js` from the `ep_example` plugin:
* `"authorize": "ep_example/index.js:authorize"`
* `"authorize": "ep_example/index.js"`
* `"authorize": "ep_example/index:authorize"`
* `"authorize": "ep_example/index"`
* `"authorize": "ep_example:authorize"`
* `"authorize": "ep_example"`
### Client hooks and server hooks ### Client hooks and server hooks
@ -170,8 +202,8 @@ file](https://docs.npmjs.com/files/package.json), called package.json, in the
project root - this file contains various metadata relevant to your plugin, such project root - this file contains various metadata relevant to your plugin, such
as the name and version number, author, project hompage, contributors, a short as the name and version number, author, project hompage, contributors, a short
description, etc. If you publish your plugin on npm, these metadata are used for description, etc. If you publish your plugin on npm, these metadata are used for
package search etc., but it's necessary for Etherpad-lite plugins, even if you package search etc., but it's necessary for Etherpad plugins, even if you don't
don't publish your plugin. publish your plugin.
```json ```json
{ {
@ -197,11 +229,7 @@ HTML templating. See the following link for more information about EJS:
Etherpad allows you to easily create front-end tests for plugins. Etherpad allows you to easily create front-end tests for plugins.
1. Create a new folder 1. Create a new folder: `%your_plugin%/static/tests/frontend/specs`
``` 2. Put your spec file in there. (Example spec files are visible in
%your_plugin%/static/tests/frontend/specs `%etherpad_root_folder%/frontend/tests/specs`.)
``` 3. Visit http://yourserver.com/frontend/tests and your front-end tests will run.
2. Put your spec file in here (Example spec files are visible in
%etherpad_root_folder%/frontend/tests/specs)
3. Visit http://yourserver.com/frontend/tests your front-end tests will run.