Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / db / migrations / 0087_ip_address_log.py @ bdedfd9d

History | View | Annotate | Download (18.7 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
        for ip in orm.IPAddress.objects.filter(nic__isnull=False).select_related("nic").all():
13
            server_id = ip.nic.machine_id
14
            orm.IPAddressLog.objects.create(server_id=server_id,
15
                                            network_id=ip.network_id,
16
                                            address=ip.address)
17

    
18
    def backwards(self, orm):
19
        "Write your backwards methods here."
20
        orm.IPAddressLog.objects.all().delete()
21

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

    
230
    complete_apps = ['db']
231
    symmetrical = True