2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Hooks
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The hooks are modules that add functionality to the core. They are loaded during the server boot.
							 
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Structure
  
						 
					
						
							
								
									
										
										
										
											2019-07-18 19:28:52 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### File structure
  
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								module.exports = strapi => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  const hook = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    /**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  Default options
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     */
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    defaults: {
							 
						 
					
						
							
								
									
										
										
										
											2018-10-18 11:25:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      // config object
							 
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    /**
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  Initialize the hook
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     */
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    async initialize() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      // await someAsyncCode()
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      // const settings = {...this.defaults, ...strapi.config.hook.settings.**};
							 
						 
					
						
							
								
									
										
										
										
											2019-07-18 19:28:52 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    },
							 
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return hook;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  `defaults`  (object): Contains the default configurations. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `initialize`  (function): Called during the server boot. 
						 
					
						
							
								
									
										
										
										
											2017-10-11 15:17:08 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The [configurations ](#configuration-and-activation ) of the hook are accessible through `strapi.config.hook.settings.**` .
							 
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The hooks are accessible through the `strapi.hook`  variable.
							 
						 
					
						
							
								
									
										
										
										
											2017-10-11 15:17:08 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-10-18 11:25:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Node modules
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Every folder that follows this name pattern `strapi-hook-*`  in your `./node_modules`  folder will be loaded as a hook.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-10-11 15:17:08 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								A hook needs to follow the structure below:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2018-10-18 11:25:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/strapi-hook-[...]
							 
						 
					
						
							
								
									
										
										
										
											2018-06-08 23:05:48 +10:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								└─── lib
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     -  index.js
							 
						 
					
						
							
								
									
										
										
										
											2017-10-11 15:17:08 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  LICENSE.md 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  package.json 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  README.md 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `index.js`  is the entry point to your hook. It should look like the example above.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-10-18 11:25:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Custom hooks
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-07-05 03:05:36 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The framework allows to load hooks from the project directly without having to install them from npm. It's a great way to take advantage of the features of the hooks system for code that doesn't need to be shared between apps. To achieve this, you have to create a `./hooks`  folder at the root of your project and put the hooks into it.
							 
						 
					
						
							
								
									
										
										
										
											2018-10-18 11:25:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/project
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								└─── admin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								└─── api
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								└─── config
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								└─── hooks
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								│   └─── strapi-documentation
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								│        - index.js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								│   └─── strapi-server-side-rendering
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								│        - index.js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								└─── public
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  favicon.ico 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  package.json 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  server.js 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Configuration and activation
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								To activate and configure your hook with custom options, you need to edit your `./config/hook.js`  file in your Strapi app.
							 
						 
					
						
							
								
									
										
										
										
											2019-07-18 19:28:52 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								module.exports = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  settings: {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'hook-name': {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      enabled: true,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    },
							 
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  },
							 
						 
					
						
							
								
									
										
										
										
											2020-05-25 18:11:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
									
										
										
										
											2017-10-10 11:15:24 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```