mirror of
				https://github.com/strapi/strapi.git
				synced 2025-10-26 07:30:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			30 lines
		
	
	
		
			604 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			604 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| module.exports = async (ctx, next) => {
 | |
|   const ratelimit = require('koa2-ratelimit').RateLimit;
 | |
| 
 | |
|   const message = [
 | |
|     {
 | |
|       messages: [
 | |
|         {
 | |
|           id: 'Auth.form.error.ratelimit',
 | |
|           message: 'Too many attempts, please try again in a minute.',
 | |
|         },
 | |
|       ],
 | |
|     },
 | |
|   ];
 | |
| 
 | |
|   return ratelimit.middleware(
 | |
|     Object.assign(
 | |
|       {},
 | |
|       {
 | |
|         interval: 1 * 60 * 1000,
 | |
|         max: 5,
 | |
|         prefixKey: `${ctx.request.path}:${ctx.request.ip}`,
 | |
|         message,
 | |
|       },
 | |
|       strapi.config.get('plugin.users-permissions.ratelimit')
 | |
|     )
 | |
|   )(ctx, next);
 | |
| };
 | 
