API
Feathers core API is very small and an initialized application provides the same functionality as an Express 4 application. The differences and additional methods and their usage are outlined in this chapter. For the service API refer to the Services chapter.
configure
app.configure(callback)
runs a callback
function with the application as the context (this
). It can be used to initialize plugins or services.
function setupService() {
this.use('/todos', todoService);
}
app.configure(setupService);
listen
app.listen([port])
starts the application on the given port. It will first call the original Express app.listen([port]), then run app.setup(server)
(see below) with the server object and then return the server object.
setup
app.setup(server)
is used to initialize all services by calling each services .setup(app, path)
method (if available).
It will also use the server
instance passed (e.g. through http.createServer
) to set up SocketIO (if enabled) and any other provider that might require the server instance.
Normally app.setup
will be called automatically when starting the application via app.listen([port])
but there are cases when you need to initialize the server separately as described in the VHost, SSL and sub-app chapter.
use
app.use([path], service)
works just like Express app.use([path], middleware) but additionally allows to register a service object (an object which at least provides one of the service methods as outlined in the Services section) instead of the middleware function. Note that REST services are registered in the same order as any other middleware so the below example will allow the /todos
service only to Passport authenticated users.
// Serve public folder for everybody
app.use(feathers.static(__dirname + '/public');
// Make sure that everything else only works with authentication
app.use(function(req,res,next){
if(req.isAuthenticated()){
next();
} else {
// 401 Not Authorized
next(new Error(401));
}
});
// Add a service.
app.use('/todos', {
get(id) {
return Promise.resolve({
id,
description: `You have to do ${name}!`
});
}
});
service
app.service(path [, service])
does two things. It either returns the Feathers wrapped service object for the given path or registers a new service for that path.
app.service(path)
returns the wrapped service object for the given path. Feathers internally creates a new object from each registered service. This means that the object returned by service(path)
will provide the same methods and functionality as your original service object but also functionality added by Feathers and its plugins (most notably it is possible to listen to service events). path
can be the service name with or without leading and trailing slashes.
app.use('/my/todos', {
create(data) {
return Promise.resolve(data);
}
});
var todoService = app.service('my/todos');
// todoService is an event emitter
todoService.on('created', todo =>
console.log('Created todo', todo)
);
You can use app.service(path, service)
instead app.use(path, service)
if you want to be more explicit that you are registering a service. It is called internally by app.use([path], service)
if a service object is passed. app.service
does not provide the Express app.use
functionality and does not check the service object for valid methods.