forked from uncloud/uncloud
112 lines
6.3 KiB
Python
112 lines
6.3 KiB
Python
|
# Generated by Django 3.1 on 2020-12-13 10:38
|
||
|
|
||
|
from django.conf import settings
|
||
|
from django.db import migrations, models
|
||
|
import django.db.models.deletion
|
||
|
|
||
|
|
||
|
class Migration(migrations.Migration):
|
||
|
|
||
|
initial = True
|
||
|
|
||
|
dependencies = [
|
||
|
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||
|
]
|
||
|
|
||
|
operations = [
|
||
|
migrations.CreateModel(
|
||
|
name='VMCluster',
|
||
|
fields=[
|
||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('extra_data', models.JSONField(blank=True, editable=False, null=True)),
|
||
|
('name', models.CharField(max_length=128, unique=True)),
|
||
|
],
|
||
|
options={
|
||
|
'abstract': False,
|
||
|
},
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='VMDiskImageProduct',
|
||
|
fields=[
|
||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('extra_data', models.JSONField(blank=True, editable=False, null=True)),
|
||
|
('name', models.CharField(max_length=256)),
|
||
|
('is_os_image', models.BooleanField(default=False)),
|
||
|
('is_public', models.BooleanField(default=False, editable=False)),
|
||
|
('size_in_gb', models.FloatField(blank=True, null=True)),
|
||
|
('import_url', models.URLField(blank=True, null=True)),
|
||
|
('image_source', models.CharField(max_length=128, null=True)),
|
||
|
('image_source_type', models.CharField(max_length=128, null=True)),
|
||
|
('storage_class', models.CharField(choices=[('HDD', 'HDD'), ('SSD', 'SSD')], default='SSD', max_length=32)),
|
||
|
('status', models.CharField(choices=[('PENDING', 'Pending'), ('AWAITING_PAYMENT', 'Awaiting payment'), ('BEING_CREATED', 'Being created'), ('SCHEDULED', 'Scheduled'), ('ACTIVE', 'Active'), ('MODIFYING', 'Modifying'), ('DELETED', 'Deleted'), ('DISABLED', 'Disabled'), ('UNUSABLE', 'Unusable')], default='PENDING', max_length=32)),
|
||
|
('owner', models.ForeignKey(editable=False, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||
|
],
|
||
|
options={
|
||
|
'abstract': False,
|
||
|
},
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='VMHost',
|
||
|
fields=[
|
||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('extra_data', models.JSONField(blank=True, editable=False, null=True)),
|
||
|
('hostname', models.CharField(max_length=253, unique=True)),
|
||
|
('physical_cores', models.IntegerField(default=0)),
|
||
|
('usable_cores', models.IntegerField(default=0)),
|
||
|
('usable_ram_in_gb', models.FloatField(default=0)),
|
||
|
('status', models.CharField(choices=[('PENDING', 'Pending'), ('AWAITING_PAYMENT', 'Awaiting payment'), ('BEING_CREATED', 'Being created'), ('SCHEDULED', 'Scheduled'), ('ACTIVE', 'Active'), ('MODIFYING', 'Modifying'), ('DELETED', 'Deleted'), ('DISABLED', 'Disabled'), ('UNUSABLE', 'Unusable')], default='PENDING', max_length=32)),
|
||
|
('vmcluster', models.ForeignKey(blank=True, editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, to='uncloud_vm.vmcluster')),
|
||
|
],
|
||
|
options={
|
||
|
'abstract': False,
|
||
|
},
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='VMProduct',
|
||
|
fields=[
|
||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('name', models.CharField(blank=True, max_length=32, null=True)),
|
||
|
('cores', models.IntegerField()),
|
||
|
('ram_in_gb', models.FloatField()),
|
||
|
('vmcluster', models.ForeignKey(blank=True, editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, to='uncloud_vm.vmcluster')),
|
||
|
('vmhost', models.ForeignKey(blank=True, editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, to='uncloud_vm.vmhost')),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='VMSnapshotProduct',
|
||
|
fields=[
|
||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('gb_ssd', models.FloatField(editable=False)),
|
||
|
('gb_hdd', models.FloatField(editable=False)),
|
||
|
('vm', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='snapshots', to='uncloud_vm.vmproduct')),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='VMNetworkCard',
|
||
|
fields=[
|
||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('mac_address', models.BigIntegerField()),
|
||
|
('ip_address', models.GenericIPAddressField(blank=True, null=True)),
|
||
|
('vm', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='uncloud_vm.vmproduct')),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='VMDiskProduct',
|
||
|
fields=[
|
||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('size_in_gb', models.FloatField(blank=True)),
|
||
|
('disk_type', models.CharField(choices=[('ceph/ssd', 'Ceph Ssd'), ('ceph/hdd', 'Ceph Hdd'), ('local/ssd', 'Local Ssd'), ('local/hdd', 'Local Hdd')], default='ceph/ssd', max_length=20)),
|
||
|
('image', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='uncloud_vm.vmdiskimageproduct')),
|
||
|
('vm', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='uncloud_vm.vmproduct')),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='VMWithOSProduct',
|
||
|
fields=[
|
||
|
('vmproduct_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='uncloud_vm.vmproduct')),
|
||
|
('primary_disk', models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, to='uncloud_vm.vmdiskproduct')),
|
||
|
],
|
||
|
bases=('uncloud_vm.vmproduct',),
|
||
|
),
|
||
|
]
|