This repository has been archived on 2026-02-15. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
breakpilot-pwa/backend/alembic/versions/20260115_1900_006_teacher_feedback.py
BreakPilot Dev 19855efacc
Some checks failed
Tests / Go Tests (push) Has been cancelled
Tests / Python Tests (push) Has been cancelled
Tests / Integration Tests (push) Has been cancelled
Tests / Go Lint (push) Has been cancelled
Tests / Python Lint (push) Has been cancelled
Tests / Security Scan (push) Has been cancelled
Tests / All Checks Passed (push) Has been cancelled
Security Scanning / Secret Scanning (push) Has been cancelled
Security Scanning / Dependency Vulnerability Scan (push) Has been cancelled
Security Scanning / Go Security Scan (push) Has been cancelled
Security Scanning / Python Security Scan (push) Has been cancelled
Security Scanning / Node.js Security Scan (push) Has been cancelled
Security Scanning / Docker Image Security (push) Has been cancelled
Security Scanning / Security Summary (push) Has been cancelled
CI/CD Pipeline / Go Tests (push) Has been cancelled
CI/CD Pipeline / Python Tests (push) Has been cancelled
CI/CD Pipeline / Website Tests (push) Has been cancelled
CI/CD Pipeline / Linting (push) Has been cancelled
CI/CD Pipeline / Security Scan (push) Has been cancelled
CI/CD Pipeline / Docker Build & Push (push) Has been cancelled
CI/CD Pipeline / Integration Tests (push) Has been cancelled
CI/CD Pipeline / Deploy to Staging (push) Has been cancelled
CI/CD Pipeline / Deploy to Production (push) Has been cancelled
CI/CD Pipeline / CI Summary (push) Has been cancelled
ci/woodpecker/manual/build-ci-image Pipeline was successful
ci/woodpecker/manual/main Pipeline failed
feat: BreakPilot PWA - Full codebase (clean push without large binaries)
All services: admin-v2, studio-v2, website, ai-compliance-sdk,
consent-service, klausur-service, voice-service, and infrastructure.
Large PDFs and compiled binaries excluded via .gitignore.
2026-02-11 13:25:58 +01:00

46 lines
1.8 KiB
Python

"""Add teacher_feedback table for Phase 7.
Revision ID: 006_teacher_feedback
Revises: 005_lesson_reflections
Create Date: 2026-01-15 19:00:00.000000
"""
from alembic import op
import sqlalchemy as sa
# revision identifiers
revision = '006_teacher_feedback'
down_revision = '005_lesson_reflections'
branch_labels = None
depends_on = None
def upgrade() -> None:
"""Create teacher_feedback table."""
op.create_table(
'teacher_feedback',
sa.Column('id', sa.String(36), primary_key=True),
sa.Column('teacher_id', sa.String(100), nullable=False, index=True),
sa.Column('teacher_name', sa.String(200), default=''),
sa.Column('teacher_email', sa.String(200), default=''),
sa.Column('title', sa.String(500), nullable=False),
sa.Column('description', sa.Text, nullable=False),
sa.Column('feedback_type', sa.String(50), nullable=False, default='improvement'),
sa.Column('priority', sa.String(50), nullable=False, default='medium'),
sa.Column('status', sa.String(50), nullable=False, default='new', index=True),
sa.Column('related_feature', sa.String(50), nullable=True),
sa.Column('context_url', sa.String(500), default=''),
sa.Column('context_phase', sa.String(50), default=''),
sa.Column('context_session_id', sa.String(36), nullable=True),
sa.Column('user_agent', sa.String(500), default=''),
sa.Column('response', sa.Text, default=''),
sa.Column('responded_at', sa.DateTime, nullable=True),
sa.Column('responded_by', sa.String(100), nullable=True),
sa.Column('created_at', sa.DateTime, default=sa.func.now()),
sa.Column('updated_at', sa.DateTime, default=sa.func.now(), onupdate=sa.func.now()),
)
def downgrade() -> None:
"""Drop teacher_feedback table."""
op.drop_table('teacher_feedback')