initial commit

Signed-off-by: ale <ale@manalejandro.com>
Este commit está contenido en:
ale
2025-08-16 23:07:29 +02:00
padre 0dc3eb3f78
commit af164c1f8c
Se han modificado 18 ficheros con 1824 adiciones y 1788 borrados

Ver fichero

@@ -1,36 +1,61 @@
This is a [Next.js](https://nextjs.org) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app).
# API Ping Service
## Getting Started
Un servicio moderno de ping construido con Next.js 15 que permite realizar pruebas de conectividad de red de forma segura y controlada.
First, run the development server:
## 🚀 Características
- **Rate Limiting**: Máximo 10 peticiones por minuto por IP para prevenir abuso
- **Validación de seguridad**: Bloquea IPs privadas, localhost y rangos reservados
- **Interfaz moderna**: UI responsiva con Tailwind CSS
- **Tiempo real**: Resultados en tiempo real con indicadores de progreso
- **Estadísticas completas**: Métricas detalladas de latencia, pérdida de paquetes, etc.
- **API RESTful**: Endpoints bien documentados para integración
## 🔧 Instalación
```bash
# Instalar dependencias
npm install
# Ejecutar en modo desarrollo
npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev
# Ejecutar en producción
npm run build
npm start
```
Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
## 📡 API Endpoints
You can start editing the page by modifying `app/page.js`. The page auto-updates as you edit the file.
### POST /api/ping
Realiza una prueba de ping al destino especificado.
This project uses [`next/font`](https://nextjs.org/docs/app/building-your-application/optimizing/fonts) to automatically optimize and load [Geist](https://vercel.com/font), a new font family for Vercel.
**Request Body:**
```json
{
"target": "8.8.8.8", // IP o hostname (requerido)
"count": 4, // Número de pings (1-10, default: 4)
"timeout": 5000 // Timeout en ms (1000-10000, default: 5000)
}
```
## Learn More
### GET /api/status
Obtiene información del estado del servicio y estadísticas del cliente.
To learn more about Next.js, take a look at the following resources:
## 🛡️ Seguridad
- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.
### Rate Limiting
- **Límite**: 10 peticiones por minuto por IP
- **Ventana deslizante**: Se renueva automáticamente
You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js) - your feedback and contributions are welcome!
### Validaciones
- ✅ IPs públicas válidas (IPv4/IPv6)
- ✅ Hostnames válidos según RFC 1123
- ❌ IPs privadas, localhost y rangos reservados
## Deploy on Vercel
## 🎨 Interfaz de Usuario
The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js.
Check out our [Next.js deployment documentation](https://nextjs.org/docs/app/building-your-application/deploying) for more details.
- **Responsive**: Optimizada para móviles y escritorio
- **Dark Mode**: Soporte completo para tema oscuro
- **Tiempo Real**: Indicadores de progreso durante las pruebas
- **Quick Select**: Botones rápidos para destinos comunes