mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-19 14:13:34 +01:00
134 lines
4 KiB
Markdown
134 lines
4 KiB
Markdown
|
All hooks registered to these events are called with two arguments:
|
||
|
|
||
|
1. name - the name of the hook being called
|
||
|
2. context - an object with some relevant information about the context of the call
|
||
|
|
||
|
# Server-side hooks
|
||
|
These hooks are called on server-side.
|
||
|
|
||
|
## pluginUninstall
|
||
|
Called from: src/static/js/pluginfw/installer.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. plugin_name - self-explanatory
|
||
|
|
||
|
If this hook returns an error, the callback to the uninstall function gets an error as well. This mostly seems useful for handling additional features added in based on the installation of other plugins, which is pretty cool!
|
||
|
|
||
|
## pluginInstall
|
||
|
Called from: src/static/js/pluginfw/installer.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. plugin_name - self-explanatory
|
||
|
|
||
|
If this hook returns an error, the callback to the install function gets an error, too. This seems useful for adding in features when a particular plugin is installed.
|
||
|
|
||
|
## init_`<plugin name>`
|
||
|
Called from: src/static/js/pluginfw/plugins.js
|
||
|
|
||
|
Things in context: None
|
||
|
|
||
|
This function is called after a specific plugin is initialized. This would probably be more useful than the previous two functions if you only wanted to add in features to one specific plugin.
|
||
|
|
||
|
## expressConfigure
|
||
|
Called from: src/node/server.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. app - the main application object
|
||
|
|
||
|
This is a helpful hook for changing the behavior and configuration of the application. It's called right after the application gets configured.
|
||
|
|
||
|
## expressCreateServer
|
||
|
Called from: src/node/server.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. app - the main application object (helpful for adding new paths and such)
|
||
|
|
||
|
This hook gets called after the application object has been created, but before it starts listening. This is similar to the expressConfigure hook, but it's not guaranteed that the application object will have all relevant configuration variables.
|
||
|
|
||
|
## eejsBlock_`<name>`
|
||
|
Called from: src/node/eejs/index.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. content - the content of the block
|
||
|
|
||
|
This hook gets called upon the rendering of an ejs template block. For any specific kind of block, you can change how that block gets rendered by modifying the content object passed in.
|
||
|
|
||
|
Have a look at `src/templates/pad.html` and `src/templates/timeslider.html` to see which blocks are available.
|
||
|
|
||
|
## socketio
|
||
|
Called from: src/node/hooks/express/socketio.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. app - the application object
|
||
|
2. io - the socketio object
|
||
|
|
||
|
I have no idea what this is useful for, someone else will have to add this description.
|
||
|
|
||
|
## authorize
|
||
|
Called from: src/node/hooks/express/webaccess.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. req - the request object
|
||
|
2. res - the response object
|
||
|
3. next - ?
|
||
|
4. resource - the path being accessed
|
||
|
|
||
|
This is useful for modifying the way authentication is done, especially for specific paths.
|
||
|
|
||
|
## authenticate
|
||
|
Called from: src/node/hooks/express/webaccess.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. req - the request object
|
||
|
2. res - the response object
|
||
|
3. next - ?
|
||
|
4. username - the username used (optional)
|
||
|
5. password - the password used (optional)
|
||
|
|
||
|
This is useful for modifying the way authentication is done.
|
||
|
|
||
|
## authFailure
|
||
|
Called from: src/node/hooks/express/webaccess.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. req - the request object
|
||
|
2. res - the response object
|
||
|
3. next - ?
|
||
|
|
||
|
This is useful for modifying the way authentication is done.
|
||
|
|
||
|
## handleMessage
|
||
|
Called from: src/node/handler/PadMessageHandler.js
|
||
|
|
||
|
Things in context:
|
||
|
|
||
|
1. message - the message being handled
|
||
|
2. client - the client object from socket.io
|
||
|
|
||
|
This hook will be called once a message arrive. If a plugin calls `callback(null)` the message will be dropped. However it is not possible to modify the message.
|
||
|
|
||
|
Plugins may also decide to implement custom behavior once a message arrives.
|
||
|
|
||
|
**WARNING**: handleMessage will be called, even if the client is not authorized to send this message. It's up to the plugin to check permissions.
|
||
|
|
||
|
Example:
|
||
|
|
||
|
```
|
||
|
function handleMessage ( hook, context, callback ) {
|
||
|
if ( context.message.type == 'USERINFO_UPDATE' ) {
|
||
|
// If the message type is USERINFO_UPDATE, drop the message
|
||
|
callback(null);
|
||
|
}else{
|
||
|
callback();
|
||
|
}
|
||
|
};
|
||
|
```
|