@xpresser/events-server
v0.2.0
Published
Xpresser's Official Events Server Plugin.
Downloads
5
Readme
Xpresser Events Server Plugin
STAGE: DEVELOPMENT
XpresserJs Events Server is a standalone server that uses your xpresser instance i.e $
to run tasks you have defined.
Unlike the current events system i.e $.events.emit("doSomething")
, The Events server was created for handling heavy
tasks outside the process of your HTTP requests server.
// Without Events Server
$.events.define("sayHello", () => $.log("Hello Dev!"))
// The somewhere in your app you call
$.events.emit("sayHello");
This event runs in the background but in same process. This may slow down HTTP requests when using it to handle heavy duty events. This is where EVENTS SERVER comes into place.
The Events Server uses xpresser behind the scenes but without HTTP (cli only).
Create: events-server.ts
import $ from "path/to/your/exported/xpresser/instance";
import EventServer from "@xpresser/events-server"
const es = new EventServer("SECRET_KEY", $)
// uses xpresser router behind the scenes.
es.on("convertVideo", "VideoController@convert");
// Start listening to events
es.startListening()
Note: your imported xpresser instance should not call $.boot()
Create: backend/EventsServer/Controllers/VideoController.ts
export = {
convert(es){
// Do whatever
es.reply("VideoConverted", {id: videoId})
}
}
Run the file and you will have your Xpresser Events Server
ready to take commands on a standalone server, using your
xpresser config and plugins.
Commands
The functions in the control panel can also be called from the command line.
Add to your use-xjs-cli.json
file:
{
"extensions": {
"npm://@xpresser/events-server": true
}
}
es:failed
This commands handles failed events.
| Command | Description |
|-----------------------------|--------------------------------------------------|
| xjs es:failed
| - will tell you the number of failed events |
| xjs es:failed list
| - will list all failed events. |
| xjs es:failed events
| - will list the names of the events that failed. |
| xjs es:failed delete [id]
| - will delete an event with the given id. | |
| xjs es:failed flush
| - will remove all failed events. | |