Stability: 3 - Stable
What is a hook?
A hook is a Node module that adds functionality to the Sails core. The hook specification defines the requirements a module must meet for Sails to be able to import its code and make the new functionality available. Because they can be saved separately from the core, hooks allow Sails code to be shared between apps and developers without having to modify the framework.
Hooks vs. Services
Hooks share some common features with Sails services. They both allow developers to store commonly used code in one location, and they both make new methods available globally to a Sails app. However, there are some key differences between the two concepts:
- Services cannot be saved independently of an app. While some types of hooks may be tied to a single app (see Project Hooks), other types can be developed independently of a Sails app and installed using
- Hooks have their own initialization system. This allows them to be more dynamic and configure themselves when Sails lifts.
- Hooks can add new routes to a Sails app before it lifts.
- is unlikely to be reused in another app
- won't need to behave differently in different environments (e.g. development vs. production)
For all other reusable code, hooks are the way to go!
Types of hooks
There are three types of hooks available in Sails:
- Core hooks. These hooks provide many of the common features essential to a Sails app, such as request handling, blueprint route creation, and database integration via Waterline. Core hooks are bundled with the Sails core and are thus available to every app. You will rarely have a need to call core hook methods in your code.
- Project hooks. These are hooks that live in the
api/hooksfolder of a Sails app. Project hooks provide a way to take advantage of the features of the hook system for code that doesn’t need to be shared between apps.
- Installable hooks. These hooks are installed into an app’s
npm install. Installable hooks allow developers in the Sails community to create and “plug-in”-like modules for use in Sails apps.