Files
jumpserver/apps/reports/migrations/0001_initial.py
2026-03-25 12:56:27 +08:00

88 lines
5.4 KiB
Python

# Generated by Django 4.1.13 on 2026-03-18 00:00
import common.db.fields
from django.db import migrations, models
import django.db.models.deletion
import uuid
class Migration(migrations.Migration):
initial = True
dependencies = [
('users', '0004_fix_user_wechat_phone'),
]
operations = [
migrations.CreateModel(
name='Report',
fields=[
('created_by', models.CharField(blank=True, max_length=128, null=True, verbose_name='Created by')),
('updated_by', models.CharField(blank=True, max_length=128, null=True, verbose_name='Updated by')),
('date_created', models.DateTimeField(auto_now_add=True, null=True, verbose_name='Date created')),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date updated')),
('comment', models.TextField(blank=True, default='', verbose_name='Comment')),
('id', models.UUIDField(default=uuid.uuid4, primary_key=True, serialize=False)),
('org_id', models.CharField(blank=True, db_index=True, default='', max_length=36, verbose_name='Organization')),
('name', models.CharField(max_length=128, verbose_name='Name')),
('is_periodic', models.BooleanField(default=False, verbose_name='Periodic run')),
('interval', models.IntegerField(blank=True, default=24, null=True, verbose_name='Interval')),
('crontab', models.CharField(blank=True, default='', max_length=128, verbose_name='Crontab')),
('start_time', models.DateTimeField(blank=True, help_text='Datetime when the schedule should begin triggering the task to run', null=True, verbose_name='Start Datetime')),
('date_last_run', models.DateTimeField(blank=True, null=True, verbose_name='Date last run')),
('tp', models.CharField(max_length=64, verbose_name='Type')),
('is_builtin', models.BooleanField(default=False, verbose_name='Is builtin')),
('is_active', models.BooleanField(default=True, verbose_name='Is active')),
('range_days', models.PositiveIntegerField(default=7, verbose_name='Range days')),
('filters', models.JSONField(default=dict, verbose_name='Filters')),
('recipients', common.db.fields.JSONManyToManyField(default=dict, to='users.User', verbose_name='Recipients')),
],
options={
'verbose_name': 'Report',
'ordering': ['-date_created'],
'unique_together': {('org_id', 'name')},
},
),
migrations.CreateModel(
name='ReportExecution',
fields=[
('org_id', models.CharField(blank=True, db_index=True, default='', max_length=36, verbose_name='Organization')),
('id', models.UUIDField(default=uuid.uuid4, primary_key=True, serialize=False)),
('status', models.CharField(choices=[('pending', 'Pending'), ('running', 'Running'), ('success', 'Success'), ('failed', 'Failed')], default='pending', max_length=16)),
('date_created', models.DateTimeField(auto_now_add=True)),
('date_start', models.DateTimeField(db_index=True, null=True)),
('date_finished', models.DateTimeField(null=True)),
('duration', models.DecimalField(decimal_places=2, default=0, max_digits=10)),
('trigger', models.CharField(choices=[('manual', 'Manual'), ('timing', 'Timing')], default='manual', max_length=128)),
('snapshot', models.JSONField(default=dict)),
('summary', models.JSONField(default=dict)),
('report', models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='executions', to='reports.report')),
],
options={
'ordering': ('org_id', '-date_start'),
},
),
migrations.CreateModel(
name='ReportSendRecord',
fields=[
('created_by', models.CharField(blank=True, max_length=128, null=True, verbose_name='Created by')),
('updated_by', models.CharField(blank=True, max_length=128, null=True, verbose_name='Updated by')),
('date_created', models.DateTimeField(auto_now_add=True, null=True, verbose_name='Date created')),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date updated')),
('comment', models.TextField(blank=True, default='', verbose_name='Comment')),
('id', models.UUIDField(default=uuid.uuid4, primary_key=True, serialize=False)),
('org_id', models.CharField(blank=True, db_index=True, default='', max_length=36, verbose_name='Organization')),
('backend', models.CharField(blank=True, default='', max_length=32)),
('receiver', models.CharField(blank=True, default='', max_length=128)),
('report_url', models.TextField(blank=True, default='')),
('is_success', models.BooleanField(default=True)),
('error', models.TextField(blank=True, default='')),
('detail', models.TextField(blank=True, default='')),
('execution', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='send_records', to='reports.reportexecution')),
],
options={
'ordering': ['-date_created'],
},
),
]