Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / db / migrations / 0080_nics_to_ips.py @ e9b5ecff

History | View | Annotate | Download (20 kB)

1
# -*- coding: utf-8 -*-
2
import datetime
3
from south.db import db
4
from south.v2 import DataMigration
5
from django.db import models
6

    
7
class Migration(DataMigration):
8

    
9
    def forwards(self, orm):
10
        "Write your forwards methods here."
11
        # Note: Remember to use orm['appname.ModelName'] rather than "from appname.models..."
12
        # Delete stale NICs
13
        orm.NetworkInterface.objects.filter(machine__deleted=True).delete()
14
        for nic in orm.NetworkInterface.objects.select_related('machine',
15
                                                               'network').all():
16
            userid = nic.machine.userid
17
            nic.userid = userid
18
            nic.save()
19
            network = nic.network
20
            for attr in ["ipv4", "ipv6"]:
21
                address = getattr(nic, attr)
22
                if address:
23
                    ipversion = 4 if attr == "ipv4" else 6
24
                    subnet = nic.network.subnets.get(ipversion=ipversion)
25
                    orm.IPAddress.objects.create(network=network,
26
                                                 subnet=subnet,
27
                                                 nic=nic,
28
                                                 userid=userid,
29
                                                 address=address)
30

    
31

    
32
    def backwards(self, orm):
33
        "Write your backwards methods here."
34
        for ip in orm.IPAddress.objects.filter(deleted=False):
35
            nic = ip.nic
36
            attr = "ipv4" if nic.subnet.ipversion == 4 else "ipv6"
37
            setattr(nic, attr, ip.address)
38
            nic.save()
39

    
40

    
41
    models = {
42
        'db.backend': {
43
            'Meta': {'ordering': "['clustername']", 'object_name': 'Backend'},
44
            'clustername': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128'}),
45
            'ctotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
46
            'dfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
47
            'disk_templates': ('synnefo.db.fields.SeparatedValuesField', [], {'null': 'True'}),
48
            'drained': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
49
            'dtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
50
            'hash': ('django.db.models.fields.CharField', [], {'max_length': '40'}),
51
            'hypervisor': ('django.db.models.fields.CharField', [], {'default': "'kvm'", 'max_length': '32'}),
52
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
53
            'index': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0', 'unique': 'True'}),
54
            'mfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
55
            'mtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
56
            'offline': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
57
            'password_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'blank': 'True'}),
58
            'pinst_cnt': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
59
            'port': ('django.db.models.fields.PositiveIntegerField', [], {'default': '5080'}),
60
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
61
            'username': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True', 'blank': 'True'})
62
        },
63
        'db.backendnetwork': {
64
            'Meta': {'unique_together': "(('network', 'backend'),)", 'object_name': 'BackendNetwork'},
65
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'networks'", 'on_delete': 'models.PROTECT', 'to': "orm['db.Backend']"}),
66
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
67
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
68
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
69
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
70
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
71
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
72
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
73
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
74
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
75
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'backend_networks'", 'to': "orm['db.Network']"}),
76
            'operstate': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '30'}),
77
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'})
78
        },
79
        'db.bridgepooltable': {
80
            'Meta': {'object_name': 'BridgePoolTable'},
81
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
82
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
83
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
84
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
85
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
86
            'size': ('django.db.models.fields.IntegerField', [], {})
87
        },
88
        'db.flavor': {
89
            'Meta': {'unique_together': "(('cpu', 'ram', 'disk', 'disk_template'),)", 'object_name': 'Flavor'},
90
            'cpu': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
91
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
92
            'disk': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
93
            'disk_template': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
94
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
95
            'ram': ('django.db.models.fields.IntegerField', [], {'default': '0'})
96
        },
97
        'db.floatingip': {
98
            'Meta': {'object_name': 'FloatingIP'},
99
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
100
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
101
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
102
            'ipv4': ('django.db.models.fields.IPAddressField', [], {'unique': 'True', 'max_length': '15', 'db_index': 'True'}),
103
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'floating_ips'", 'null': 'True', 'to': "orm['db.VirtualMachine']"}),
104
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'floating_ips'", 'to': "orm['db.Network']"}),
105
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'floating_ips'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['db.QuotaHolderSerial']"}),
106
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '128', 'db_index': 'True'})
107
        },
108
        'db.ipaddress': {
109
            'Meta': {'unique_together': "(('network', 'address'),)", 'object_name': 'IPAddress'},
110
            'address': ('django.db.models.fields.CharField', [], {'max_length': '64'}),
111
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
112
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
113
            'floating_ip': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
114
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
115
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'ips'", 'to': "orm['db.Network']"}),
116
            'nic': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'ips'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['db.NetworkInterface']"}),
117
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'ips'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['db.QuotaHolderSerial']"}),
118
            'subnet': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'ips'", 'to': "orm['db.Subnet']"}),
119
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
120
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '128', 'db_index': 'True'})
121
        },
122
        'db.ippooltable': {
123
            'Meta': {'object_name': 'IPPoolTable'},
124
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
125
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
126
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
127
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
128
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
129
            'size': ('django.db.models.fields.IntegerField', [], {}),
130
            'subnet': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'ip_pools'", 'null': 'True', 'to': "orm['db.Subnet']"})
131
        },
132
        'db.macprefixpooltable': {
133
            'Meta': {'object_name': 'MacPrefixPoolTable'},
134
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
135
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
136
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
137
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
138
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
139
            'size': ('django.db.models.fields.IntegerField', [], {})
140
        },
141
        'db.network': {
142
            'Meta': {'object_name': 'Network'},
143
            'action': ('django.db.models.fields.CharField', [], {'default': 'None', 'max_length': '32', 'null': 'True'}),
144
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
145
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}),
146
            'drained': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
147
            'external_router': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
148
            'flavor': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
149
            'floating_ip_pool': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
150
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
151
            'link': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
152
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
153
            'machines': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['db.VirtualMachine']", 'through': "orm['db.NetworkInterface']", 'symmetrical': 'False'}),
154
            'mode': ('django.db.models.fields.CharField', [], {'max_length': '16', 'null': 'True'}),
155
            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
156
            'public': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}),
157
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'network'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['db.QuotaHolderSerial']"}),
158
            'state': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '32'}),
159
            'tags': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
160
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
161
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'db_index': 'True'})
162
        },
163
        'db.networkinterface': {
164
            'Meta': {'object_name': 'NetworkInterface'},
165
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
166
            'device_owner': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
167
            'dirty': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
168
            'firewall_profile': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
169
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
170
            'index': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
171
            'ipv4': ('django.db.models.fields.CharField', [], {'max_length': '15', 'null': 'True'}),
172
            'ipv6': ('django.db.models.fields.CharField', [], {'max_length': '100', 'null': 'True'}),
173
            'mac': ('django.db.models.fields.CharField', [], {'max_length': '32', 'unique': 'True', 'null': 'True'}),
174
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.VirtualMachine']"}),
175
            'name': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
176
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.Network']"}),
177
            'security_groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['db.SecurityGroup']", 'null': 'True', 'symmetrical': 'False'}),
178
            'state': ('django.db.models.fields.CharField', [], {'default': "'ACTIVE'", 'max_length': '32'}),
179
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
180
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'db_index': 'True'})
181
        },
182
        'db.quotaholderserial': {
183
            'Meta': {'ordering': "['serial']", 'object_name': 'QuotaHolderSerial'},
184
            'accept': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
185
            'pending': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'db_index': 'True'}),
186
            'resolved': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
187
            'serial': ('django.db.models.fields.BigIntegerField', [], {'primary_key': 'True', 'db_index': 'True'})
188
        },
189
        'db.securitygroup': {
190
            'Meta': {'object_name': 'SecurityGroup'},
191
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
192
            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'})
193
        },
194
        'db.subnet': {
195
            'Meta': {'object_name': 'Subnet'},
196
            'cidr': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
197
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}),
198
            'dhcp': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
199
            'dns_nameservers': ('synnefo.db.fields.SeparatedValuesField', [], {'null': 'True'}),
200
            'gateway': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
201
            'host_routes': ('synnefo.db.fields.SeparatedValuesField', [], {'null': 'True'}),
202
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
203
            'ipversion': ('django.db.models.fields.IntegerField', [], {'default': '4'}),
204
            'name': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
205
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'subnets'", 'to': "orm['db.Network']"})
206
        },
207
        'db.virtualmachine': {
208
            'Meta': {'object_name': 'VirtualMachine'},
209
            'action': ('django.db.models.fields.CharField', [], {'default': 'None', 'max_length': '30', 'null': 'True'}),
210
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machines'", 'null': 'True', 'on_delete': 'models.PROTECT', 'to': "orm['db.Backend']"}),
211
            'backend_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
212
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
213
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
214
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
215
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
216
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
217
            'buildpercentage': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
218
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
219
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}),
220
            'flavor': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['db.Flavor']", 'on_delete': 'models.PROTECT'}),
221
            'hostid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
222
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
223
            'imageid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
224
            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
225
            'operstate': ('django.db.models.fields.CharField', [], {'default': "'BUILD'", 'max_length': '30'}),
226
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machine'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['db.QuotaHolderSerial']"}),
227
            'suspended': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
228
            'task': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
229
            'task_job_id': ('django.db.models.fields.BigIntegerField', [], {'null': 'True'}),
230
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
231
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '100', 'db_index': 'True'})
232
        },
233
        'db.virtualmachinediagnostic': {
234
            'Meta': {'ordering': "['-created']", 'object_name': 'VirtualMachineDiagnostic'},
235
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
236
            'details': ('django.db.models.fields.TextField', [], {'null': 'True'}),
237
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
238
            'level': ('django.db.models.fields.CharField', [], {'max_length': '20'}),
239
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'diagnostics'", 'to': "orm['db.VirtualMachine']"}),
240
            'message': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
241
            'source': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
242
            'source_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'})
243
        },
244
        'db.virtualmachinemetadata': {
245
            'Meta': {'unique_together': "(('meta_key', 'vm'),)", 'object_name': 'VirtualMachineMetadata'},
246
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
247
            'meta_key': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
248
            'meta_value': ('django.db.models.fields.CharField', [], {'max_length': '500'}),
249
            'vm': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'metadata'", 'to': "orm['db.VirtualMachine']"})
250
        }
251
    }
252

    
253
    complete_apps = ['db']
254
    symmetrical = True