jumpserver/apps/assets/migrations/0108_auto_20220816_1022.py

69 lines
2.2 KiB
Python
Raw Normal View History

2022-08-16 03:09:30 +00:00
# Generated by Django 3.2.14 on 2022-08-16 02:22
import time
from django.db import migrations, models
2022-08-17 03:54:18 +00:00
from django.db.models import Count
2022-08-16 03:09:30 +00:00
def migrate_command_filter_to_assets(apps, schema_editor):
command_filter_model = apps.get_model('assets', 'CommandFilter')
count = 0
bulk_size = 1000
print("\nStart migrate command filters to assets")
while True:
start = time.time()
command_filters = command_filter_model.objects.all() \
2022-08-18 03:15:17 +00:00
.prefetch_related('system_users')[count:count + bulk_size]
2022-08-16 03:09:30 +00:00
if not command_filters:
break
2022-08-18 03:15:17 +00:00
count += len(command_filters)
2022-08-16 03:09:30 +00:00
updated = []
for command_filter in command_filters:
command_filter.accounts = [s.username for s in command_filter.system_users.all()]
updated.append(command_filter)
command_filter_model.objects.bulk_update(updated, ['accounts'])
print("Create assets: {}-{} using: {:.2f}s".format(
2022-08-18 03:15:17 +00:00
count - len(command_filters), count, time.time() - start
2022-08-16 03:09:30 +00:00
))
def migrate_command_filter_apps(apps, schema_editor):
command_filter_model = apps.get_model('assets', 'CommandFilter')
command_filters = command_filter_model.objects \
.annotate(app_count=Count('applications')) \
.filter(app_count__gt=0)
for command_filter in command_filters:
app_ids = command_filter.applications.all().values_list('id', flat=True)
try:
command_filter.assets.add(*app_ids)
except:
print("Migrate command filter apps failed: {}, skip".format(command_filter.id))
class Migration(migrations.Migration):
dependencies = [
2022-08-18 03:15:17 +00:00
('assets', '0107_auto_20220811_1511'),
2022-08-16 03:09:30 +00:00
]
operations = [
migrations.AddField(
model_name='commandfilter',
name='accounts',
field=models.JSONField(default=list, verbose_name='Accounts'),
),
migrations.RunPython(migrate_command_filter_to_assets),
migrations.RemoveField(
model_name='commandfilter',
name='system_users',
),
migrations.RunPython(migrate_command_filter_apps),
migrations.RemoveField(
model_name='commandfilter',
name='applications',
),
]