saas-market-analysis-dubai/apps/reports/migrations/0001_initial.py
2025-09-17 03:04:22 +05:30

58 lines
3.1 KiB
Python

# Generated by Django 4.2.24 on 2025-09-16 18:48
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
import uuid
class Migration(migrations.Migration):
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name='ReportTemplate',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('name', models.CharField(max_length=255)),
('description', models.TextField(blank=True)),
('report_type', models.CharField(max_length=50)),
('template_config', models.JSONField(default=dict)),
('is_active', models.BooleanField(default=True)),
('created_by', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='created_templates', to=settings.AUTH_USER_MODEL)),
],
options={
'db_table': 'report_templates',
},
),
migrations.CreateModel(
name='Report',
fields=[
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
('title', models.CharField(max_length=255)),
('report_type', models.CharField(choices=[('transaction_summary', 'Transaction Summary'), ('area_analysis', 'Area Analysis'), ('market_trends', 'Market Trends'), ('forecast_report', 'Forecast Report'), ('custom', 'Custom Report')], max_length=50)),
('format', models.CharField(choices=[('pdf', 'PDF'), ('excel', 'Excel'), ('csv', 'CSV')], max_length=10)),
('status', models.CharField(choices=[('pending', 'Pending'), ('processing', 'Processing'), ('completed', 'Completed'), ('failed', 'Failed')], default='pending', max_length=20)),
('file_path', models.CharField(blank=True, max_length=500)),
('file_size', models.BigIntegerField(blank=True, null=True)),
('parameters', models.JSONField(default=dict)),
('error_message', models.TextField(blank=True)),
('expires_at', models.DateTimeField(blank=True, null=True)),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='reports', to=settings.AUTH_USER_MODEL)),
],
options={
'db_table': 'reports',
'indexes': [models.Index(fields=['user', 'created_at'], name='reports_user_id_90e09e_idx'), models.Index(fields=['status'], name='reports_status_e83c1d_idx'), models.Index(fields=['report_type'], name='reports_report__ff8b25_idx')],
},
),
]