Revision 97fffe10

b/snf-cyclades-app/synnefo/db/migrations/0063_auto__add_field_quotaholderserial_accept__add_field_quotaholderserial_.py
1
# encoding: utf-8
2
import datetime
3
from south.db import db
4
from south.v2 import SchemaMigration
5
from django.db import models
6

  
7
class Migration(SchemaMigration):
8

  
9
    def forwards(self, orm):
10
        
11
        # Adding field 'QuotaHolderSerial.accept'
12
        db.add_column('db_quotaholderserial', 'accept', self.gf('django.db.models.fields.BooleanField')(default=False, blank=True), keep_default=False)
13

  
14
        # Adding field 'QuotaHolderSerial.resolved'
15
        db.add_column('db_quotaholderserial', 'resolved', self.gf('django.db.models.fields.BooleanField')(default=False, blank=True), keep_default=False)
16

  
17

  
18
    def backwards(self, orm):
19
        
20
        # Deleting field 'QuotaHolderSerial.accept'
21
        db.delete_column('db_quotaholderserial', 'accept')
22

  
23
        # Deleting field 'QuotaHolderSerial.resolved'
24
        db.delete_column('db_quotaholderserial', 'resolved')
25

  
26

  
27
    models = {
28
        'db.backend': {
29
            'Meta': {'object_name': 'Backend'},
30
            'clustername': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128'}),
31
            'ctotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
32
            'dfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
33
            'drained': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
34
            'dtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
35
            'hash': ('django.db.models.fields.CharField', [], {'max_length': '40'}),
36
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
37
            'index': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0', 'unique': 'True'}),
38
            'mfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
39
            'mtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
40
            'offline': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
41
            'password_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'blank': 'True'}),
42
            'pinst_cnt': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
43
            'port': ('django.db.models.fields.PositiveIntegerField', [], {'default': '5080'}),
44
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
45
            'username': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True', 'blank': 'True'})
46
        },
47
        'db.backendnetwork': {
48
            'Meta': {'unique_together': "(('network', 'backend'),)", 'object_name': 'BackendNetwork'},
49
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'networks'", 'to': "orm['db.Backend']"}),
50
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
51
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
52
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
53
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
54
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
55
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
56
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
57
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
58
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
59
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'backend_networks'", 'to': "orm['db.Network']"}),
60
            'operstate': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '30'}),
61
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'})
62
        },
63
        'db.bridgepooltable': {
64
            'Meta': {'object_name': 'BridgePoolTable'},
65
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
66
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
67
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
68
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
69
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
70
            'size': ('django.db.models.fields.IntegerField', [], {})
71
        },
72
        'db.flavor': {
73
            'Meta': {'unique_together': "(('cpu', 'ram', 'disk', 'disk_template'),)", 'object_name': 'Flavor'},
74
            'cpu': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
75
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
76
            'disk': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
77
            'disk_template': ('django.db.models.fields.CharField', [], {'default': "'plain'", 'max_length': '32'}),
78
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
79
            'ram': ('django.db.models.fields.IntegerField', [], {'default': '0'})
80
        },
81
        'db.ippooltable': {
82
            'Meta': {'object_name': 'IPPoolTable'},
83
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
84
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
85
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
86
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
87
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
88
            'size': ('django.db.models.fields.IntegerField', [], {})
89
        },
90
        'db.macprefixpooltable': {
91
            'Meta': {'object_name': 'MacPrefixPoolTable'},
92
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
93
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
94
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
95
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
96
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
97
            'size': ('django.db.models.fields.IntegerField', [], {})
98
        },
99
        'db.network': {
100
            'Meta': {'object_name': 'Network'},
101
            'action': ('django.db.models.fields.CharField', [], {'default': 'None', 'max_length': '32', 'null': 'True'}),
102
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
103
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
104
            'dhcp': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
105
            'flavor': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
106
            'gateway': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
107
            'gateway6': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
108
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
109
            'link': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
110
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
111
            'machines': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['db.VirtualMachine']", 'through': "orm['db.NetworkInterface']", 'symmetrical': 'False'}),
112
            'mode': ('django.db.models.fields.CharField', [], {'max_length': '16', 'null': 'True'}),
113
            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
114
            'pool': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'network'", 'unique': 'True', 'null': 'True', 'to': "orm['db.IPPoolTable']"}),
115
            'public': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
116
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'network'", 'null': 'True', 'to': "orm['db.QuotaHolderSerial']"}),
117
            'state': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '32'}),
118
            'subnet': ('django.db.models.fields.CharField', [], {'default': "'10.0.0.0/24'", 'max_length': '32'}),
119
            'subnet6': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
120
            'tags': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
121
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
122
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'db_index': 'True'})
123
        },
124
        'db.networkinterface': {
125
            'Meta': {'object_name': 'NetworkInterface'},
126
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
127
            'dirty': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
128
            'firewall_profile': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
129
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
130
            'index': ('django.db.models.fields.IntegerField', [], {}),
131
            'ipv4': ('django.db.models.fields.CharField', [], {'max_length': '15', 'null': 'True'}),
132
            'ipv6': ('django.db.models.fields.CharField', [], {'max_length': '100', 'null': 'True'}),
133
            'mac': ('django.db.models.fields.CharField', [], {'max_length': '32', 'unique': 'True', 'null': 'True'}),
134
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.VirtualMachine']"}),
135
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.Network']"}),
136
            'state': ('django.db.models.fields.CharField', [], {'default': "'ACTIVE'", 'max_length': '32'}),
137
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'})
138
        },
139
        'db.quotaholderserial': {
140
            'Meta': {'object_name': 'QuotaHolderSerial'},
141
            'accept': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
142
            'accepted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
143
            'pending': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'db_index': 'True', 'blank': 'True'}),
144
            'rejected': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
145
            'resolved': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
146
            'serial': ('django.db.models.fields.BigIntegerField', [], {'primary_key': 'True', 'db_index': 'True'})
147
        },
148
        'db.virtualmachine': {
149
            'Meta': {'object_name': 'VirtualMachine'},
150
            'action': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
151
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machines'", 'null': 'True', 'to': "orm['db.Backend']"}),
152
            'backend_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
153
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
154
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
155
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
156
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
157
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
158
            'buildpercentage': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
159
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
160
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
161
            'flavor': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['db.Flavor']"}),
162
            'hostid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
163
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
164
            'imageid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
165
            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
166
            'operstate': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
167
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machine'", 'null': 'True', 'to': "orm['db.QuotaHolderSerial']"}),
168
            'suspended': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
169
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
170
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '100', 'db_index': 'True'})
171
        },
172
        'db.virtualmachinediagnostic': {
173
            'Meta': {'object_name': 'VirtualMachineDiagnostic'},
174
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
175
            'details': ('django.db.models.fields.TextField', [], {'null': 'True'}),
176
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
177
            'level': ('django.db.models.fields.CharField', [], {'max_length': '20'}),
178
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'diagnostics'", 'to': "orm['db.VirtualMachine']"}),
179
            'message': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
180
            'source': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
181
            'source_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'})
182
        },
183
        'db.virtualmachinemetadata': {
184
            'Meta': {'unique_together': "(('meta_key', 'vm'),)", 'object_name': 'VirtualMachineMetadata'},
185
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
186
            'meta_key': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
187
            'meta_value': ('django.db.models.fields.CharField', [], {'max_length': '500'}),
188
            'vm': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'metadata'", 'to': "orm['db.VirtualMachine']"})
189
        }
190
    }
191

  
192
    complete_apps = ['db']
b/snf-cyclades-app/synnefo/db/migrations/0064_serials.py
1
# encoding: 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
        for serial in orm.QuotaHolderSerial.objects.filter(pending=False):
12
            if serial.accepted:
13
                serial.accept = True
14
            serial.resolved = True
15
            serial.save()
16

  
17

  
18
    def backwards(self, orm):
19
        "Write your backwards methods here."
20
        for serial in orm.QuotaHolderSerial.objects.filter(pending=False):
21
            if serial.accept:
22
                serial.accepted = True
23
            else:
24
                serial.rejected = True
25
            serial.save()
26

  
27

  
28
    models = {
29
        'db.backend': {
30
            'Meta': {'object_name': 'Backend'},
31
            'clustername': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128'}),
32
            'ctotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
33
            'dfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
34
            'drained': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
35
            'dtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
36
            'hash': ('django.db.models.fields.CharField', [], {'max_length': '40'}),
37
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
38
            'index': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0', 'unique': 'True'}),
39
            'mfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
40
            'mtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
41
            'offline': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
42
            'password_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'blank': 'True'}),
43
            'pinst_cnt': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
44
            'port': ('django.db.models.fields.PositiveIntegerField', [], {'default': '5080'}),
45
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
46
            'username': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True', 'blank': 'True'})
47
        },
48
        'db.backendnetwork': {
49
            'Meta': {'unique_together': "(('network', 'backend'),)", 'object_name': 'BackendNetwork'},
50
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'networks'", 'to': "orm['db.Backend']"}),
51
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
52
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
53
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
54
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
55
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
56
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
57
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
58
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
59
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
60
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'backend_networks'", 'to': "orm['db.Network']"}),
61
            'operstate': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '30'}),
62
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'})
63
        },
64
        'db.bridgepooltable': {
65
            'Meta': {'object_name': 'BridgePoolTable'},
66
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
67
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
68
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
69
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
70
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
71
            'size': ('django.db.models.fields.IntegerField', [], {})
72
        },
73
        'db.flavor': {
74
            'Meta': {'unique_together': "(('cpu', 'ram', 'disk', 'disk_template'),)", 'object_name': 'Flavor'},
75
            'cpu': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
76
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
77
            'disk': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
78
            'disk_template': ('django.db.models.fields.CharField', [], {'default': "'plain'", 'max_length': '32'}),
79
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
80
            'ram': ('django.db.models.fields.IntegerField', [], {'default': '0'})
81
        },
82
        'db.ippooltable': {
83
            'Meta': {'object_name': 'IPPoolTable'},
84
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
85
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
86
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
87
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
88
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
89
            'size': ('django.db.models.fields.IntegerField', [], {})
90
        },
91
        'db.macprefixpooltable': {
92
            'Meta': {'object_name': 'MacPrefixPoolTable'},
93
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
94
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
95
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
96
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
97
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
98
            'size': ('django.db.models.fields.IntegerField', [], {})
99
        },
100
        'db.network': {
101
            'Meta': {'object_name': 'Network'},
102
            'action': ('django.db.models.fields.CharField', [], {'default': 'None', 'max_length': '32', 'null': 'True'}),
103
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
104
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
105
            'dhcp': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
106
            'flavor': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
107
            'gateway': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
108
            'gateway6': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
109
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
110
            'link': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
111
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
112
            'machines': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['db.VirtualMachine']", 'through': "orm['db.NetworkInterface']", 'symmetrical': 'False'}),
113
            'mode': ('django.db.models.fields.CharField', [], {'max_length': '16', 'null': 'True'}),
114
            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
115
            'pool': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'network'", 'unique': 'True', 'null': 'True', 'to': "orm['db.IPPoolTable']"}),
116
            'public': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
117
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'network'", 'null': 'True', 'to': "orm['db.QuotaHolderSerial']"}),
118
            'state': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '32'}),
119
            'subnet': ('django.db.models.fields.CharField', [], {'default': "'10.0.0.0/24'", 'max_length': '32'}),
120
            'subnet6': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
121
            'tags': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
122
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
123
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'db_index': 'True'})
124
        },
125
        'db.networkinterface': {
126
            'Meta': {'object_name': 'NetworkInterface'},
127
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
128
            'dirty': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
129
            'firewall_profile': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
130
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
131
            'index': ('django.db.models.fields.IntegerField', [], {}),
132
            'ipv4': ('django.db.models.fields.CharField', [], {'max_length': '15', 'null': 'True'}),
133
            'ipv6': ('django.db.models.fields.CharField', [], {'max_length': '100', 'null': 'True'}),
134
            'mac': ('django.db.models.fields.CharField', [], {'max_length': '32', 'unique': 'True', 'null': 'True'}),
135
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.VirtualMachine']"}),
136
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.Network']"}),
137
            'state': ('django.db.models.fields.CharField', [], {'default': "'ACTIVE'", 'max_length': '32'}),
138
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'})
139
        },
140
        'db.quotaholderserial': {
141
            'Meta': {'object_name': 'QuotaHolderSerial'},
142
            'accept': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
143
            'accepted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
144
            'pending': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'db_index': 'True', 'blank': 'True'}),
145
            'rejected': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
146
            'resolved': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
147
            'serial': ('django.db.models.fields.BigIntegerField', [], {'primary_key': 'True', 'db_index': 'True'})
148
        },
149
        'db.virtualmachine': {
150
            'Meta': {'object_name': 'VirtualMachine'},
151
            'action': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
152
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machines'", 'null': 'True', 'to': "orm['db.Backend']"}),
153
            'backend_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
154
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
155
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
156
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
157
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
158
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
159
            'buildpercentage': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
160
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
161
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
162
            'flavor': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['db.Flavor']"}),
163
            'hostid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
164
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
165
            'imageid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
166
            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
167
            'operstate': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
168
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machine'", 'null': 'True', 'to': "orm['db.QuotaHolderSerial']"}),
169
            'suspended': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
170
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
171
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '100', 'db_index': 'True'})
172
        },
173
        'db.virtualmachinediagnostic': {
174
            'Meta': {'object_name': 'VirtualMachineDiagnostic'},
175
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
176
            'details': ('django.db.models.fields.TextField', [], {'null': 'True'}),
177
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
178
            'level': ('django.db.models.fields.CharField', [], {'max_length': '20'}),
179
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'diagnostics'", 'to': "orm['db.VirtualMachine']"}),
180
            'message': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
181
            'source': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
182
            'source_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'})
183
        },
184
        'db.virtualmachinemetadata': {
185
            'Meta': {'unique_together': "(('meta_key', 'vm'),)", 'object_name': 'VirtualMachineMetadata'},
186
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
187
            'meta_key': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
188
            'meta_value': ('django.db.models.fields.CharField', [], {'max_length': '500'}),
189
            'vm': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'metadata'", 'to': "orm['db.VirtualMachine']"})
190
        }
191
    }
192

  
193
    complete_apps = ['db']
b/snf-cyclades-app/synnefo/db/migrations/0065_auto__del_field_quotaholderserial_rejected__del_field_quotaholderseria.py
1
# encoding: utf-8
2
import datetime
3
from south.db import db
4
from south.v2 import SchemaMigration
5
from django.db import models
6

  
7
class Migration(SchemaMigration):
8

  
9
    def forwards(self, orm):
10
        
11
        # Deleting field 'QuotaHolderSerial.rejected'
12
        db.delete_column('db_quotaholderserial', 'rejected')
13

  
14
        # Deleting field 'QuotaHolderSerial.accepted'
15
        db.delete_column('db_quotaholderserial', 'accepted')
16

  
17

  
18
    def backwards(self, orm):
19
        
20
        # Adding field 'QuotaHolderSerial.rejected'
21
        db.add_column('db_quotaholderserial', 'rejected', self.gf('django.db.models.fields.BooleanField')(default=False, blank=True), keep_default=False)
22

  
23
        # Adding field 'QuotaHolderSerial.accepted'
24
        db.add_column('db_quotaholderserial', 'accepted', self.gf('django.db.models.fields.BooleanField')(default=False, blank=True), keep_default=False)
25

  
26

  
27
    models = {
28
        'db.backend': {
29
            'Meta': {'object_name': 'Backend'},
30
            'clustername': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128'}),
31
            'ctotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
32
            'dfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
33
            'drained': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
34
            'dtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
35
            'hash': ('django.db.models.fields.CharField', [], {'max_length': '40'}),
36
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
37
            'index': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0', 'unique': 'True'}),
38
            'mfree': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
39
            'mtotal': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
40
            'offline': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
41
            'password_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'blank': 'True'}),
42
            'pinst_cnt': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
43
            'port': ('django.db.models.fields.PositiveIntegerField', [], {'default': '5080'}),
44
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
45
            'username': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True', 'blank': 'True'})
46
        },
47
        'db.backendnetwork': {
48
            'Meta': {'unique_together': "(('network', 'backend'),)", 'object_name': 'BackendNetwork'},
49
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'networks'", 'to': "orm['db.Backend']"}),
50
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
51
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
52
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
53
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
54
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
55
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
56
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
57
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
58
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
59
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'backend_networks'", 'to': "orm['db.Network']"}),
60
            'operstate': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '30'}),
61
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'})
62
        },
63
        'db.bridgepooltable': {
64
            'Meta': {'object_name': 'BridgePoolTable'},
65
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
66
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
67
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
68
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
69
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
70
            'size': ('django.db.models.fields.IntegerField', [], {})
71
        },
72
        'db.flavor': {
73
            'Meta': {'unique_together': "(('cpu', 'ram', 'disk', 'disk_template'),)", 'object_name': 'Flavor'},
74
            'cpu': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
75
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
76
            'disk': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
77
            'disk_template': ('django.db.models.fields.CharField', [], {'default': "'plain'", 'max_length': '32'}),
78
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
79
            'ram': ('django.db.models.fields.IntegerField', [], {'default': '0'})
80
        },
81
        'db.ippooltable': {
82
            'Meta': {'object_name': 'IPPoolTable'},
83
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
84
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
85
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
86
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
87
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
88
            'size': ('django.db.models.fields.IntegerField', [], {})
89
        },
90
        'db.macprefixpooltable': {
91
            'Meta': {'object_name': 'MacPrefixPoolTable'},
92
            'available_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
93
            'base': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
94
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
95
            'offset': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
96
            'reserved_map': ('django.db.models.fields.TextField', [], {'default': "''"}),
97
            'size': ('django.db.models.fields.IntegerField', [], {})
98
        },
99
        'db.network': {
100
            'Meta': {'object_name': 'Network'},
101
            'action': ('django.db.models.fields.CharField', [], {'default': 'None', 'max_length': '32', 'null': 'True'}),
102
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
103
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
104
            'dhcp': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
105
            'flavor': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
106
            'gateway': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
107
            'gateway6': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
108
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
109
            'link': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
110
            'mac_prefix': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
111
            'machines': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['db.VirtualMachine']", 'through': "orm['db.NetworkInterface']", 'symmetrical': 'False'}),
112
            'mode': ('django.db.models.fields.CharField', [], {'max_length': '16', 'null': 'True'}),
113
            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
114
            'pool': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'network'", 'unique': 'True', 'null': 'True', 'to': "orm['db.IPPoolTable']"}),
115
            'public': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
116
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'network'", 'null': 'True', 'to': "orm['db.QuotaHolderSerial']"}),
117
            'state': ('django.db.models.fields.CharField', [], {'default': "'PENDING'", 'max_length': '32'}),
118
            'subnet': ('django.db.models.fields.CharField', [], {'default': "'10.0.0.0/24'", 'max_length': '32'}),
119
            'subnet6': ('django.db.models.fields.CharField', [], {'max_length': '64', 'null': 'True'}),
120
            'tags': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
121
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
122
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'db_index': 'True'})
123
        },
124
        'db.networkinterface': {
125
            'Meta': {'object_name': 'NetworkInterface'},
126
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
127
            'dirty': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
128
            'firewall_profile': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
129
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
130
            'index': ('django.db.models.fields.IntegerField', [], {}),
131
            'ipv4': ('django.db.models.fields.CharField', [], {'max_length': '15', 'null': 'True'}),
132
            'ipv6': ('django.db.models.fields.CharField', [], {'max_length': '100', 'null': 'True'}),
133
            'mac': ('django.db.models.fields.CharField', [], {'max_length': '32', 'unique': 'True', 'null': 'True'}),
134
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.VirtualMachine']"}),
135
            'network': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nics'", 'to': "orm['db.Network']"}),
136
            'state': ('django.db.models.fields.CharField', [], {'default': "'ACTIVE'", 'max_length': '32'}),
137
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'})
138
        },
139
        'db.quotaholderserial': {
140
            'Meta': {'object_name': 'QuotaHolderSerial'},
141
            'accept': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
142
            'pending': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'db_index': 'True', 'blank': 'True'}),
143
            'resolved': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
144
            'serial': ('django.db.models.fields.BigIntegerField', [], {'primary_key': 'True', 'db_index': 'True'})
145
        },
146
        'db.virtualmachine': {
147
            'Meta': {'object_name': 'VirtualMachine'},
148
            'action': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
149
            'backend': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machines'", 'null': 'True', 'to': "orm['db.Backend']"}),
150
            'backend_hash': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True'}),
151
            'backendjobid': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
152
            'backendjobstatus': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
153
            'backendlogmsg': ('django.db.models.fields.TextField', [], {'null': 'True'}),
154
            'backendopcode': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
155
            'backendtime': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1, 1, 1, 0, 0)'}),
156
            'buildpercentage': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
157
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
158
            'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
159
            'flavor': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['db.Flavor']"}),
160
            'hostid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
161
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
162
            'imageid': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
163
            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
164
            'operstate': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
165
            'serial': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'virtual_machine'", 'null': 'True', 'to': "orm['db.QuotaHolderSerial']"}),
166
            'suspended': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
167
            'updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
168
            'userid': ('django.db.models.fields.CharField', [], {'max_length': '100', 'db_index': 'True'})
169
        },
170
        'db.virtualmachinediagnostic': {
171
            'Meta': {'object_name': 'VirtualMachineDiagnostic'},
172
            'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
173
            'details': ('django.db.models.fields.TextField', [], {'null': 'True'}),
174
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
175
            'level': ('django.db.models.fields.CharField', [], {'max_length': '20'}),
176
            'machine': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'diagnostics'", 'to': "orm['db.VirtualMachine']"}),
177
            'message': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
178
            'source': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
179
            'source_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'})
180
        },
181
        'db.virtualmachinemetadata': {
182
            'Meta': {'unique_together': "(('meta_key', 'vm'),)", 'object_name': 'VirtualMachineMetadata'},
183
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
184
            'meta_key': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
185
            'meta_value': ('django.db.models.fields.CharField', [], {'max_length': '500'}),
186
            'vm': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'metadata'", 'to': "orm['db.VirtualMachine']"})
187
        }
188
    }
189

  
190
    complete_apps = ['db']
b/snf-cyclades-app/synnefo/db/models.py
193 193

  
194 194

  
195 195
class QuotaHolderSerial(models.Model):
196
    """Model representing a serial for a Quotaholder Commission.
197

  
198
    serial:   The serial that Quotaholder assigned to this commission
199
    pending:  Whether it has been decided to accept or reject this commission
200
    accept:   If pending is False, this attribute indicates whether to accept
201
              or reject this commission
202
    resolved: Whether this commission has been accepted or rejected to
203
              Quotaholder.
204

  
205
    """
196 206
    serial = models.BigIntegerField(null=False, primary_key=True,
197 207
                                    db_index=True)
198 208
    pending = models.BooleanField(default=True, db_index=True)
199
    accepted = models.BooleanField(default=False)
200
    rejected = models.BooleanField(default=False)
209
    accept = models.BooleanField(default=False)
210
    resolved = models.BooleanField(default=False)
201 211

  
202 212
    class Meta:
203 213
        verbose_name = u'Quota Serial'
204 214
        ordering = ["serial"]
205 215

  
206
    def save(self, *args, **kwargs):
207
        self.pending = not (self.accepted or self.rejected)
208
        super(QuotaHolderSerial, self).save(*args, **kwargs)
209

  
210 216

  
211 217
class VirtualMachine(models.Model):
212 218
    # The list of possible actions for a VM

Also available in: Unified diff