mirror of https://github.com/jumpserver/jumpserver
73 lines
2.5 KiB
Python
73 lines
2.5 KiB
Python
# Generated by Django 2.2.7 on 2019-12-17 09:13
|
|
|
|
from django.db import migrations, models
|
|
import django.db.models.deletion
|
|
from django.core.exceptions import ObjectDoesNotExist
|
|
|
|
|
|
def migrate_task_data(apps, schema_editor):
|
|
task_model = apps.get_model("ops", "Task")
|
|
db_alias = schema_editor.connection.alias
|
|
tasks = task_model.objects.using(db_alias).all()
|
|
for task in tasks:
|
|
try:
|
|
latest_history = task.history.latest()
|
|
except ObjectDoesNotExist:
|
|
latest_history = None
|
|
try:
|
|
latest_adhoc = task.adhoc.latest()
|
|
except ObjectDoesNotExist:
|
|
latest_adhoc = None
|
|
if latest_history and latest_history.adhoc:
|
|
latest_history.hosts_amount = latest_history.adhoc.hosts.count()
|
|
latest_history.save()
|
|
total_run_amount = task.history.all().count()
|
|
success_run_amount = task.history.filter(is_success=True).count()
|
|
task.latest_history = latest_history
|
|
task.latest_adhoc = latest_adhoc
|
|
task.total_run_amount = total_run_amount
|
|
task.success_run_amount = success_run_amount
|
|
task.save()
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
|
|
dependencies = [
|
|
('ops', '0008_auto_20190919_2100'),
|
|
]
|
|
|
|
operations = [
|
|
migrations.AddField(
|
|
model_name='task',
|
|
name='latest_adhoc',
|
|
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='task_latest', to='ops.AdHoc'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='task',
|
|
name='latest_history',
|
|
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='task_latest', to='ops.AdHocRunHistory'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='task',
|
|
name='success_run_amount',
|
|
field=models.IntegerField(default=0),
|
|
),
|
|
migrations.AddField(
|
|
model_name='task',
|
|
name='total_run_amount',
|
|
field=models.IntegerField(default=0),
|
|
),
|
|
migrations.AddField(
|
|
model_name='adhocrunhistory',
|
|
name='hosts_amount',
|
|
field=models.IntegerField(default=0, verbose_name='Host amount'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='adhocrunhistory',
|
|
name='task_display',
|
|
field=models.CharField(blank=True, default='', max_length=128,
|
|
verbose_name='Task display'),
|
|
),
|
|
migrations.RunPython(migrate_task_data),
|
|
]
|