# Generated by Django 3.1.6 on 2021-06-05 16:10 import common.fields.model from django.conf import settings import django.core.validators from django.db import migrations, models import django.db.models.deletion import simple_history.models import uuid from django.utils import timezone from django.db import migrations, transaction def migrate_old_authbook_to_history(apps, schema_editor): authbook_model = apps.get_model("assets", "AuthBook") history_model = apps.get_model("assets", "HistoricalAuthBook") db_alias = schema_editor.connection.alias print() while True: authbooks = authbook_model.objects.using(db_alias).filter(is_latest=False)[:20] if not authbooks: break historys = [] authbook_ids = [] # Todo: 或许能优化成更新那样 for authbook in authbooks: authbook_ids.append(authbook.id) history = history_model() for attr in [ 'id', 'username', 'password', 'private_key', 'public_key', 'version', 'comment', 'created_by', 'asset', 'date_created', 'date_updated' ]: setattr(history, attr, getattr(authbook, attr)) history.history_type = '-' history.history_date = timezone.now() historys.append(history) with transaction.atomic(): print(" Migrate old auth book to history table: {} items".format(len(authbook_ids))) history_model.objects.bulk_create(historys, ignore_conflicts=True) authbook_model.objects.filter(id__in=authbook_ids).delete() class Migration(migrations.Migration): dependencies = [ migrations.swappable_dependency(settings.AUTH_USER_MODEL), ('assets', '0071_systemuser_type'), ] operations = [ migrations.CreateModel( name='HistoricalAuthBook', fields=[ ('org_id', models.CharField(blank=True, db_index=True, default='', max_length=36, verbose_name='Organization')), ('id', models.UUIDField(db_index=True, default=uuid.uuid4)), ('name', models.CharField(max_length=128, verbose_name='Name')), ('username', models.CharField(blank=True, db_index=True, max_length=128, validators=[django.core.validators.RegexValidator('^[0-9a-zA-Z_@\\-\\.]*$', 'Special char not allowed')], verbose_name='Username')), ('password', common.fields.model.EncryptCharField(blank=True, max_length=256, null=True, verbose_name='Password')), ('private_key', common.fields.model.EncryptTextField(blank=True, null=True, verbose_name='SSH private key')), ('public_key', common.fields.model.EncryptTextField(blank=True, null=True, verbose_name='SSH public key')), ('comment', models.TextField(blank=True, verbose_name='Comment')), ('date_created', models.DateTimeField(blank=True, editable=False, verbose_name='Date created')), ('date_updated', models.DateTimeField(blank=True, editable=False, verbose_name='Date updated')), ('created_by', models.CharField(max_length=128, null=True, verbose_name='Created by')), ('version', models.IntegerField(default=1, verbose_name='Version')), ('is_latest', models.BooleanField(default=False, verbose_name='Latest version')), ('history_id', models.AutoField(primary_key=True, serialize=False)), ('history_date', models.DateTimeField()), ('history_change_reason', models.CharField(max_length=100, null=True)), ('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)), ('asset', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='assets.asset', verbose_name='Asset')), ('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)), ], options={ 'verbose_name': 'historical AuthBook', 'ordering': ('-history_date', '-history_id'), 'get_latest_by': 'history_date', }, bases=(simple_history.models.HistoricalChanges, models.Model), ), migrations.RunPython(migrate_old_authbook_to_history) ]