10 KiB
| description |
|---|
| Complete workflow for developing E-Learning Platform backend |
E-Learning Backend Development Workflow
Complete guide for developing the E-Learning Platform backend using TypeScript and TSOA.
🎯 Overview
This workflow covers the entire development process from initial setup to deployment.
Phase 1: Initial Setup
1.1 Environment Setup
Follow the Setup Workflow:
# Clone repository
git clone <repository-url>
cd e-learning/Backend
# Install dependencies
npm install
# Install TypeScript and TSOA
npm install -D typescript @types/node @types/express ts-node nodemon
npm install tsoa swagger-ui-express
# Setup environment
cp .env.example .env
# Edit .env with your configuration
# Start Docker services
docker compose up -d
# Run migrations
npx prisma migrate dev
# Seed database
npx prisma db seed
# Start dev server
npm run dev
1.2 Verify Setup
# Test health endpoint
curl http://localhost:4000/health
# Test login
curl -X POST http://localhost:4000/api/auth/login \
-H "Content-Type: application/json" \
-d '{"username": "admin", "password": "admin123"}'
Phase 2: Database Design
2.1 Design Schema
Review and update prisma/schema.prisma:
model User {
id Int @id @default(autoincrement())
username String @unique
email String @unique
password String
role_id Int
role Role @relation(fields: [role_id], references: [id])
profile Profile?
created_at DateTime @default(now())
updated_at DateTime @updatedAt
}
model Course {
id Int @id @default(autoincrement())
title Json // { th: "", en: "" }
description Json
price Decimal @db.Decimal(10, 2)
is_free Boolean @default(false)
have_certificate Boolean @default(false)
status CourseStatus @default(DRAFT)
category_id Int
category Category @relation(fields: [category_id], references: [id])
created_by Int
creator User @relation(fields: [created_by], references: [id])
chapters Chapter[]
instructors CourseInstructor[]
created_at DateTime @default(now())
updated_at DateTime @updatedAt
@@index([category_id])
@@index([status])
}
2.2 Create Migration
Follow the Database Migration Workflow:
npx prisma migrate dev --name initial_schema
Phase 3: Core Features Development
3.1 Authentication System
Create endpoints:
POST /api/auth/register- User registrationPOST /api/auth/login- User loginPOST /api/auth/logout- User logoutPOST /api/auth/refresh- Refresh token
Implementation steps:
- Create TSOA controller with
@Route,@Postdecorators - Create TypeScript service with interfaces
- Implement JWT middleware
- Write tests
See Create API Endpoint Workflow for detailed examples.
3.2 Course Management
Follow the Create API Endpoint Workflow for:
Instructor endpoints:
POST /api/instructor/courses- Create courseGET /api/instructor/courses- List my coursesPUT /api/instructor/courses/:id- Update courseDELETE /api/instructor/courses/:id- Delete coursePOST /api/instructor/courses/:id/submit- Submit for approval
Public endpoints:
GET /api/courses- List approved coursesGET /api/courses/:id- Get course details
Student endpoints:
POST /api/students/courses/:id/enroll- Enroll in courseGET /api/students/courses- My enrolled courses
3.3 Chapters & Lessons
Create endpoints:
POST /api/instructor/courses/:courseId/chapters- Create chapterPOST /api/instructor/courses/:courseId/chapters/:chapterId/lessons- Create lessonPUT /api/instructor/courses/:courseId/lessons/:lessonId- Update lessonDELETE /api/instructor/courses/:courseId/lessons/:lessonId- Delete lesson
Key features:
- Multi-language support (th/en)
- Lesson types (video, text, pdf, quiz)
- Sequential ordering
- Prerequisites system
3.4 File Upload System
Follow the File Upload Workflow:
Implement:
- Video upload for lessons
- Attachment upload (PDF, DOC, etc.)
- Image upload for thumbnails
- S3/MinIO integration
- File validation (type, size)
Endpoints:
POST /api/instructor/lessons/:lessonId/video- Upload videoPOST /api/instructor/lessons/:lessonId/attachments- Upload attachmentsGET /api/students/lessons/:lessonId/attachments/:id/download- Download
3.5 Quiz System
Create endpoints:
POST /api/instructor/lessons/:lessonId/quiz- Create quizPOST /api/instructor/quizzes/:quizId/questions- Add questionGET /api/students/quizzes/:quizId- Get quizPOST /api/students/quizzes/:quizId/submit- Submit quiz
Features:
- Multiple choice questions
- Time limits
- Attempt limits
- Cooldown periods
- Score policies (HIGHEST, LATEST, AVERAGE)
3.6 Progress Tracking
Implement:
- Video progress tracking (save every 5 seconds)
- Lesson completion
- Course progress calculation
- Certificate generation
Endpoints:
POST /api/students/lessons/:lessonId/progress- Save progressGET /api/students/lessons/:lessonId/progress- Get progressPOST /api/students/lessons/:lessonId/complete- Mark completeGET /api/students/courses/:courseId/certificate- Get certificate
Phase 4: Testing
Follow the Testing Workflow:
4.1 Unit Tests
# Test services
npm test -- unit/auth.service.test.js
npm test -- unit/course.service.test.js
4.2 Integration Tests
# Test API endpoints
npm test -- integration/auth.test.js
npm test -- integration/courses.test.js
npm test -- integration/lessons.test.js
4.3 Coverage
npm test -- --coverage
Target: >80% coverage
Phase 5: Optimization
5.1 Database Optimization
- Add indexes for frequently queried fields
- Optimize N+1 queries
- Use
selectto limit fields - Implement pagination
model Course {
// ...
@@index([category_id])
@@index([status])
@@index([created_at])
}
5.2 Rate Limiting
Use express-rate-limit middleware to limit requests (e.g., 100 requests per 15 minutes).
Phase 6: Security Hardening
6.1 Security Checklist
- Input validation on all endpoints
- SQL injection prevention (Prisma handles this)
- XSS prevention (sanitize HTML)
- CSRF protection
- Rate limiting
- CORS configuration
- Helmet.js for security headers
- File upload validation
- Strong JWT secrets
- Password hashing (bcrypt)
6.2 Implement Security Middleware
Use helmet() for security headers and configure CORS with allowed origins.
Phase 7: Documentation
7.1 API Documentation
TSOA automatically generates Swagger/OpenAPI documentation:
import swaggerUi from 'swagger-ui-express';
app.use('/api-docs', swaggerUi.serve, async (_req, res) => {
return res.send(
swaggerUi.generateHTML(await import('../public/swagger.json'))
);
});
Generate documentation:
npm run tsoa:gen
Access at: http://localhost:4000/api-docs
7.2 Code Documentation
- JSDoc comments for all functions
- README.md with setup instructions
- API endpoint documentation
- Database schema documentation
Phase 8: Deployment
Follow the Deployment Workflow:
8.1 Prepare for Production
# Set NODE_ENV
export NODE_ENV=production
# Install production dependencies only
npm ci --production
# Run migrations
npx prisma migrate deploy
# Build (if needed)
npm run build
8.2 Deploy with PM2
pm2 start ecosystem.config.js
pm2 save
pm2 startup
8.3 Setup Nginx
Configure reverse proxy and SSL
8.4 Monitoring
- Setup PM2 monitoring
- Configure logging
- Setup error tracking (Sentry)
- Health check endpoint
Development Best Practices
1. Code Organization
src/
├── config/ # Configuration files
├── controllers/ # Request handlers
├── middleware/ # Express middleware
├── models/ # Prisma models (generated)
├── routes/ # Route definitions
├── services/ # Business logic
├── utils/ # Utility functions
├── validators/ # Input validation
└── app.js # Express app setup
2. Git Workflow
# Create feature branch
git checkout -b feature/user-authentication
# Make changes and commit
git add .
git commit -m "feat: implement user authentication"
# Push and create PR
git push origin feature/user-authentication
3. Code Review Checklist
- Code follows style guide
- Tests written and passing
- No console.logs in production code
- Error handling implemented
- Input validation added
- Documentation updated
- No sensitive data in code
Troubleshooting
- Database error: Check
docker logs elearning-postgres, runnpx prisma db pull - Port in use: Find with
lsof -i :4000, kill withkill -9 <PID> - Prisma error: Run
npx prisma generateornpx prisma migrate reset
Resources
Quick Commands Reference
# Development
npm run dev # Start dev server (ts-node)
npm run build # Build TypeScript
npm run tsoa:gen # Generate TSOA routes & Swagger
npm test # Run tests
npm run lint # Run linter
npm run format # Format code
# Database
npx prisma studio # Open Prisma Studio
npx prisma migrate dev # Create and apply migration
npx prisma db seed # Seed database
# Docker
docker compose up -d # Start services
docker compose down # Stop services
docker compose logs -f # View logs
# PM2 (Production)
pm2 start app.js # Start app
pm2 restart app # Restart app
pm2 logs # View logs
pm2 monit # Monitor resources
Ready to build an amazing E-Learning Platform! 🚀