Implementados 4 módulos con agent swarm: 1. MERCADOPAGO INTEGRADO - SDK oficial de MercadoPago - Crear preferencias de pago - Webhooks para notificaciones - Reembolsos y cancelaciones - Estados: PENDING, PROCESSING, COMPLETED, REFUNDED 2. SISTEMA DE BONOS Y PACKS - Pack 5, Pack 10, Pack Mensual - Compra online con MP - Uso FIFO automático - Control de expiración - Aplicación en reservas 3. SUSCRIPCIONES/MEMBRESÍAS - Planes: Básico, Premium, Anual VIP - Beneficios: descuentos, reservas gratis, prioridad - Cobro recurrente vía MP - Estados: ACTIVE, PAUSED, CANCELLED - Aplicación automática en reservas 4. CLASES CON PROFESORES - Registro de coaches con verificación - Tipos: Individual, Grupal, Clínica - Horarios y disponibilidad - Reservas con pago integrado - Sistema de reseñas Endpoints nuevos: - /payments/* - Pagos MercadoPago - /bonus-packs/*, /bonuses/* - Bonos - /subscription-plans/*, /subscriptions/* - Suscripciones - /coaches/* - Profesores - /classes/*, /class-enrollments/* - Clases Variables de entorno: - MERCADOPAGO_ACCESS_TOKEN - MERCADOPAGO_PUBLIC_KEY - MERCADOPAGO_WEBHOOK_SECRET Datos de prueba: - 3 Bonus Packs - 3 Planes de suscripción - 1 Coach verificado (admin) - 3 Clases disponibles
179 lines
6.2 KiB
SQL
179 lines
6.2 KiB
SQL
/*
|
|
Warnings:
|
|
|
|
- You are about to drop the `subscription_plans` table. If the table is not empty, all the data it contains will be lost.
|
|
- You are about to drop the `user_subscriptions` table. If the table is not empty, all the data it contains will be lost.
|
|
|
|
*/
|
|
-- DropTable
|
|
PRAGMA foreign_keys=off;
|
|
DROP TABLE "subscription_plans";
|
|
PRAGMA foreign_keys=on;
|
|
|
|
-- DropTable
|
|
PRAGMA foreign_keys=off;
|
|
DROP TABLE "user_subscriptions";
|
|
PRAGMA foreign_keys=on;
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "coaches" (
|
|
"id" TEXT NOT NULL PRIMARY KEY,
|
|
"userId" TEXT NOT NULL,
|
|
"bio" TEXT,
|
|
"specialties" TEXT,
|
|
"certifications" TEXT,
|
|
"yearsExperience" INTEGER NOT NULL DEFAULT 0,
|
|
"hourlyRate" INTEGER NOT NULL DEFAULT 0,
|
|
"photoUrl" TEXT,
|
|
"isActive" BOOLEAN NOT NULL DEFAULT true,
|
|
"isVerified" BOOLEAN NOT NULL DEFAULT false,
|
|
"rating" REAL,
|
|
"reviewCount" INTEGER NOT NULL DEFAULT 0,
|
|
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" DATETIME NOT NULL,
|
|
CONSTRAINT "coaches_userId_fkey" FOREIGN KEY ("userId") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "coach_availabilities" (
|
|
"id" TEXT NOT NULL PRIMARY KEY,
|
|
"coachId" TEXT NOT NULL,
|
|
"dayOfWeek" INTEGER NOT NULL,
|
|
"startTime" TEXT NOT NULL,
|
|
"endTime" TEXT NOT NULL,
|
|
"isAvailable" BOOLEAN NOT NULL DEFAULT true,
|
|
CONSTRAINT "coach_availabilities_coachId_fkey" FOREIGN KEY ("coachId") REFERENCES "coaches" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "classes" (
|
|
"id" TEXT NOT NULL PRIMARY KEY,
|
|
"coachId" TEXT NOT NULL,
|
|
"title" TEXT NOT NULL,
|
|
"description" TEXT,
|
|
"type" TEXT NOT NULL DEFAULT 'INDIVIDUAL',
|
|
"maxStudents" INTEGER NOT NULL DEFAULT 1,
|
|
"price" INTEGER NOT NULL DEFAULT 0,
|
|
"duration" INTEGER NOT NULL DEFAULT 60,
|
|
"levelRequired" TEXT,
|
|
"isActive" BOOLEAN NOT NULL DEFAULT true,
|
|
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" DATETIME NOT NULL,
|
|
CONSTRAINT "classes_coachId_fkey" FOREIGN KEY ("coachId") REFERENCES "coaches" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "class_bookings" (
|
|
"id" TEXT NOT NULL PRIMARY KEY,
|
|
"classId" TEXT NOT NULL,
|
|
"coachId" TEXT NOT NULL,
|
|
"courtId" TEXT,
|
|
"date" DATETIME NOT NULL,
|
|
"startTime" TEXT NOT NULL,
|
|
"students" TEXT NOT NULL DEFAULT '[]',
|
|
"maxStudents" INTEGER NOT NULL DEFAULT 1,
|
|
"enrolledStudents" INTEGER NOT NULL DEFAULT 0,
|
|
"status" TEXT NOT NULL DEFAULT 'AVAILABLE',
|
|
"price" INTEGER NOT NULL DEFAULT 0,
|
|
"paymentId" TEXT,
|
|
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" DATETIME NOT NULL,
|
|
CONSTRAINT "class_bookings_classId_fkey" FOREIGN KEY ("classId") REFERENCES "classes" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "class_bookings_coachId_fkey" FOREIGN KEY ("coachId") REFERENCES "coaches" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
|
CONSTRAINT "class_bookings_courtId_fkey" FOREIGN KEY ("courtId") REFERENCES "courts" ("id") ON DELETE SET NULL ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "student_enrollments" (
|
|
"id" TEXT NOT NULL PRIMARY KEY,
|
|
"classBookingId" TEXT NOT NULL,
|
|
"userId" TEXT NOT NULL,
|
|
"paymentId" TEXT,
|
|
"status" TEXT NOT NULL DEFAULT 'PENDING',
|
|
"enrolledAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"cancelledAt" DATETIME,
|
|
CONSTRAINT "student_enrollments_classBookingId_fkey" FOREIGN KEY ("classBookingId") REFERENCES "class_bookings" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "student_enrollments_userId_fkey" FOREIGN KEY ("userId") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "coach_reviews" (
|
|
"id" TEXT NOT NULL PRIMARY KEY,
|
|
"coachId" TEXT NOT NULL,
|
|
"userId" TEXT NOT NULL,
|
|
"rating" INTEGER NOT NULL,
|
|
"comment" TEXT,
|
|
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
CONSTRAINT "coach_reviews_coachId_fkey" FOREIGN KEY ("coachId") REFERENCES "coaches" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "coach_reviews_userId_fkey" FOREIGN KEY ("userId") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "coaches_userId_key" ON "coaches"("userId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coaches_isActive_idx" ON "coaches"("isActive");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coaches_isVerified_idx" ON "coaches"("isVerified");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coaches_userId_idx" ON "coaches"("userId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coach_availabilities_coachId_idx" ON "coach_availabilities"("coachId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coach_availabilities_coachId_dayOfWeek_idx" ON "coach_availabilities"("coachId", "dayOfWeek");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coach_availabilities_dayOfWeek_idx" ON "coach_availabilities"("dayOfWeek");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "classes_coachId_idx" ON "classes"("coachId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "classes_type_idx" ON "classes"("type");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "classes_isActive_idx" ON "classes"("isActive");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "class_bookings_classId_idx" ON "class_bookings"("classId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "class_bookings_coachId_idx" ON "class_bookings"("coachId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "class_bookings_courtId_idx" ON "class_bookings"("courtId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "class_bookings_date_idx" ON "class_bookings"("date");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "class_bookings_status_idx" ON "class_bookings"("status");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "student_enrollments_userId_idx" ON "student_enrollments"("userId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "student_enrollments_status_idx" ON "student_enrollments"("status");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "student_enrollments_classBookingId_idx" ON "student_enrollments"("classBookingId");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "student_enrollments_classBookingId_userId_key" ON "student_enrollments"("classBookingId", "userId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coach_reviews_coachId_idx" ON "coach_reviews"("coachId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coach_reviews_userId_idx" ON "coach_reviews"("userId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "coach_reviews_rating_idx" ON "coach_reviews"("rating");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "coach_reviews_coachId_userId_key" ON "coach_reviews"("coachId", "userId");
|