Allocation of Resources Without Limits or Throttling
The product allocates a reusable resource or group of resources on behalf of an actor without imposing any restrictions on the size or number of resources that can be allocated.
Without limits on resource allocation, an attacker can consume all available resources, causing denial of service for legitimate users.
Comment corriger cette vulnérabilité
Stratégies de prévention pour Allocation Without Limits basées sur 3 règles de détection Shoulder.
Set size limits on body parser middleware to prevent memory exhaustion
- app.use(express.json()); - app.use(express.urlencoded({ extended: true })); + app.use(express.json({ limit: '100kb' })); + app.use(express.urlencoded({ extended: true, limit: '100kb' }));
Add 'take' limits to all relation includes to prevent unbounded data loading and resource exhaustion
import { PrismaClient } from '@prisma/client'; const prisma = new PrismaClient(); app.get('/api/users/:id', async (req, res) => { const user = await prisma.user.findUnique({ where: { id: req.params.id }, include: { - posts: true, // Could be thousands of posts - comments: true, // Could be tens of thousands + posts: { + take: 20, + orderBy: { createdAt: 'desc' }, + select: { id: true, title: true, createdAt: true }, + }, + comments: { + take: 50, + orderBy: { createdAt: 'desc' }, + }, } }); res.json(user); });
Add rate limiting to authentication and expensive API endpoints
from flask import Flask, request, jsonify - - @app.route('/api/login', methods=['POST']) + from flask_limiter import Limiter + from flask_limiter.util import get_remote_address + + limiter = Limiter(app=app, key_func=get_remote_address) + + @app.route('/api/login', methods=['POST']) + @limiter.limit("5 per minute") def login(): user = authenticate(request.json) return jsonify({'token': generate_token(user)})
Trouvez les vulnérabilités dans votre code
Utilisez Shoulder pour scanner votre code à la recherche de patterns Allocation of Resources Without Limits or Throttling. 3 règles.
# Scan with Shoulder CLI npx @shoulderdev/cli trust --cwe=770 # Or scan entire project npx @shoulderdev/cli trust .
Règles de Détection (3)
Ce qu'il faut surveiller lors des revues de code
Ces patterns indiquent des vulnérabilités potentielles Allocation of Resources Without Limits or Throttling. Recherchez-les lors des revues de code et des audits de sécurité.
Scannez votre base de code pour Allocation of Resources Without Limits or Throttling
Shoulder CLI trouve les motifs vulnérables dans toute votre base de code.