~evilnick/maas/1.2-docs-tidyup+preseed

« back to all changes in this revision

Viewing changes to src/maasserver/migrations/0043_unique_hostname_preparation.py

  • Committer: Tarmac
  • Author(s): Raphael Badin
  • Date: 2012-11-16 14:18:12 UTC
  • mfrom: (1302.1.2 ui-update-fqdn-1.2)
  • Revision ID: tarmac-20121116141812-hpe1ku99g8facmtx
[r=rvb][bug=1070765][author=rvb] Backport of 1335 (and required db migration merged in revision 1330).

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# -*- coding: utf-8 -*-
 
2
import datetime
 
3
 
 
4
from django.db import models
 
5
from django.db.models import Count
 
6
from south.db import db
 
7
from south.v2 import DataMigration
 
8
 
 
9
 
 
10
class Migration(DataMigration):
 
11
 
 
12
    def forwards(self, orm):
 
13
        # Find the nodes with duplicated hostnames.
 
14
        duplicated_hostnames = orm['maasserver.node'].objects.values_list(
 
15
            'hostname', flat=True).annotate(
 
16
                hostname_count=Count('hostname')).exclude(hostname_count=1)
 
17
        # Rename the nodes with duplicated hostnames.
 
18
        for duplicated_hostname in duplicated_hostnames:
 
19
            nodes_with_duplicated_hostnames = (
 
20
                orm['maasserver.node'].objects.filter(
 
21
                    hostname=duplicated_hostname))
 
22
            # Rename all the nodes but one.
 
23
            for node in nodes_with_duplicated_hostnames[1:]:
 
24
                number = 1
 
25
                while True:
 
26
                    new_hostname = '%s-%d' % (node.hostname, number)
 
27
                    if not orm['maasserver.node'].objects.filter(hostname=new_hostname).exists():
 
28
                        node.hostname = new_hostname
 
29
                        node.save()
 
30
                        break
 
31
                    number += 1
 
32
 
 
33
 
 
34
    def backwards(self, orm):
 
35
        pass
 
36
 
 
37
    models = {
 
38
        'auth.group': {
 
39
            'Meta': {'object_name': 'Group'},
 
40
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
41
            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
 
42
            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
 
43
        },
 
44
        'auth.permission': {
 
45
            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
 
46
            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
 
47
            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
 
48
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
49
            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
 
50
        },
 
51
        'auth.user': {
 
52
            'Meta': {'object_name': 'User'},
 
53
            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
 
54
            'email': ('django.db.models.fields.EmailField', [], {'unique': 'True', 'max_length': '75', 'blank': 'True'}),
 
55
            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
 
56
            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
 
57
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
58
            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
 
59
            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
 
60
            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
 
61
            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
 
62
            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
 
63
            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
 
64
            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
 
65
            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
 
66
        },
 
67
        'contenttypes.contenttype': {
 
68
            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
 
69
            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
 
70
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
71
            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
 
72
            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
 
73
        },
 
74
        u'maasserver.bootimage': {
 
75
            'Meta': {'unique_together': "((u'nodegroup', u'architecture', u'subarchitecture', u'release', u'purpose'),)", 'object_name': 'BootImage'},
 
76
            'architecture': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
 
77
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
78
            'nodegroup': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['maasserver.NodeGroup']"}),
 
79
            'purpose': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
 
80
            'release': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
 
81
            'subarchitecture': ('django.db.models.fields.CharField', [], {'max_length': '255'})
 
82
        },
 
83
        u'maasserver.componenterror': {
 
84
            'Meta': {'object_name': 'ComponentError'},
 
85
            'component': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40'}),
 
86
            'created': ('django.db.models.fields.DateTimeField', [], {}),
 
87
            'error': ('django.db.models.fields.CharField', [], {'max_length': '1000'}),
 
88
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
89
            'updated': ('django.db.models.fields.DateTimeField', [], {})
 
90
        },
 
91
        u'maasserver.config': {
 
92
            'Meta': {'object_name': 'Config'},
 
93
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
94
            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
 
95
            'value': ('maasserver.fields.JSONObjectField', [], {'null': 'True'})
 
96
        },
 
97
        u'maasserver.dhcplease': {
 
98
            'Meta': {'object_name': 'DHCPLease'},
 
99
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
100
            'ip': ('django.db.models.fields.IPAddressField', [], {'unique': 'True', 'max_length': '15'}),
 
101
            'mac': ('maasserver.fields.MACAddressField', [], {}),
 
102
            'nodegroup': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['maasserver.NodeGroup']"})
 
103
        },
 
104
        u'maasserver.filestorage': {
 
105
            'Meta': {'object_name': 'FileStorage'},
 
106
            'content': ('metadataserver.fields.BinaryField', [], {}),
 
107
            'filename': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
 
108
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'})
 
109
        },
 
110
        u'maasserver.macaddress': {
 
111
            'Meta': {'object_name': 'MACAddress'},
 
112
            'created': ('django.db.models.fields.DateTimeField', [], {}),
 
113
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
114
            'mac_address': ('maasserver.fields.MACAddressField', [], {'unique': 'True'}),
 
115
            'node': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['maasserver.Node']"}),
 
116
            'updated': ('django.db.models.fields.DateTimeField', [], {})
 
117
        },
 
118
        u'maasserver.node': {
 
119
            'Meta': {'object_name': 'Node'},
 
120
            'after_commissioning_action': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
 
121
            'architecture': ('django.db.models.fields.CharField', [], {'default': "u'i386/generic'", 'max_length': '31'}),
 
122
            'cpu_count': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
 
123
            'created': ('django.db.models.fields.DateTimeField', [], {}),
 
124
            'distro_series': ('django.db.models.fields.CharField', [], {'default': 'None', 'max_length': '10', 'null': 'True', 'blank': 'True'}),
 
125
            'error': ('django.db.models.fields.CharField', [], {'default': "u''", 'max_length': '255', 'blank': 'True'}),
 
126
            'hardware_details': ('maasserver.fields.XMLField', [], {'default': 'None', 'null': 'True', 'blank': 'True'}),
 
127
            'hostname': ('django.db.models.fields.CharField', [], {'default': "u''", 'max_length': '255', 'blank': 'True'}),
 
128
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
129
            'memory': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
 
130
            'netboot': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
 
131
            'nodegroup': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['maasserver.NodeGroup']", 'null': 'True'}),
 
132
            'owner': ('django.db.models.fields.related.ForeignKey', [], {'default': 'None', 'to': "orm['auth.User']", 'null': 'True', 'blank': 'True'}),
 
133
            'power_parameters': ('maasserver.fields.JSONObjectField', [], {'default': "u''", 'blank': 'True'}),
 
134
            'power_type': ('django.db.models.fields.CharField', [], {'default': "u''", 'max_length': '10', 'blank': 'True'}),
 
135
            'status': ('django.db.models.fields.IntegerField', [], {'default': '0', 'max_length': '10'}),
 
136
            'system_id': ('django.db.models.fields.CharField', [], {'default': "u'node-6b5652fe-2412-11e2-9eff-9c4e363b1c94'", 'unique': 'True', 'max_length': '41'}),
 
137
            'tags': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['maasserver.Tag']", 'symmetrical': 'False'}),
 
138
            'token': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['piston.Token']", 'null': 'True'}),
 
139
            'updated': ('django.db.models.fields.DateTimeField', [], {})
 
140
        },
 
141
        u'maasserver.nodegroup': {
 
142
            'Meta': {'object_name': 'NodeGroup'},
 
143
            'api_key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '18'}),
 
144
            'api_token': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['piston.Token']", 'unique': 'True'}),
 
145
            'cluster_name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '100', 'blank': 'True'}),
 
146
            'created': ('django.db.models.fields.DateTimeField', [], {}),
 
147
            'dhcp_key': ('django.db.models.fields.CharField', [], {'default': "u''", 'max_length': '255', 'blank': 'True'}),
 
148
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
149
            'name': ('django.db.models.fields.CharField', [], {'max_length': '80', 'blank': 'True'}),
 
150
            'status': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
 
151
            'updated': ('django.db.models.fields.DateTimeField', [], {}),
 
152
            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '36'})
 
153
        },
 
154
        u'maasserver.nodegroupinterface': {
 
155
            'Meta': {'unique_together': "((u'nodegroup', u'interface'),)", 'object_name': 'NodeGroupInterface'},
 
156
            'broadcast_ip': ('django.db.models.fields.GenericIPAddressField', [], {'default': 'None', 'max_length': '39', 'null': 'True', 'blank': 'True'}),
 
157
            'created': ('django.db.models.fields.DateTimeField', [], {}),
 
158
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
159
            'interface': ('django.db.models.fields.CharField', [], {'default': "u''", 'max_length': '255', 'blank': 'True'}),
 
160
            'ip': ('django.db.models.fields.GenericIPAddressField', [], {'max_length': '39'}),
 
161
            'ip_range_high': ('django.db.models.fields.GenericIPAddressField', [], {'default': 'None', 'max_length': '39', 'null': 'True', 'blank': 'True'}),
 
162
            'ip_range_low': ('django.db.models.fields.GenericIPAddressField', [], {'default': 'None', 'max_length': '39', 'null': 'True', 'blank': 'True'}),
 
163
            'management': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
 
164
            'nodegroup': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['maasserver.NodeGroup']"}),
 
165
            'router_ip': ('django.db.models.fields.GenericIPAddressField', [], {'default': 'None', 'max_length': '39', 'null': 'True', 'blank': 'True'}),
 
166
            'subnet_mask': ('django.db.models.fields.GenericIPAddressField', [], {'default': 'None', 'max_length': '39', 'null': 'True', 'blank': 'True'}),
 
167
            'updated': ('django.db.models.fields.DateTimeField', [], {})
 
168
        },
 
169
        u'maasserver.sshkey': {
 
170
            'Meta': {'unique_together': "((u'user', u'key'),)", 'object_name': 'SSHKey'},
 
171
            'created': ('django.db.models.fields.DateTimeField', [], {}),
 
172
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
173
            'key': ('django.db.models.fields.TextField', [], {}),
 
174
            'updated': ('django.db.models.fields.DateTimeField', [], {}),
 
175
            'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['auth.User']"})
 
176
        },
 
177
        u'maasserver.tag': {
 
178
            'Meta': {'object_name': 'Tag'},
 
179
            'comment': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
 
180
            'created': ('django.db.models.fields.DateTimeField', [], {}),
 
181
            'definition': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
 
182
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
183
            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '256'}),
 
184
            'updated': ('django.db.models.fields.DateTimeField', [], {})
 
185
        },
 
186
        u'maasserver.userprofile': {
 
187
            'Meta': {'object_name': 'UserProfile'},
 
188
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
189
            'user': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True'})
 
190
        },
 
191
        'piston.consumer': {
 
192
            'Meta': {'object_name': 'Consumer'},
 
193
            'description': ('django.db.models.fields.TextField', [], {}),
 
194
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
195
            'key': ('django.db.models.fields.CharField', [], {'max_length': '18'}),
 
196
            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
 
197
            'secret': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
 
198
            'status': ('django.db.models.fields.CharField', [], {'default': "'pending'", 'max_length': '16'}),
 
199
            'user': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'consumers'", 'null': 'True', 'to': "orm['auth.User']"})
 
200
        },
 
201
        'piston.token': {
 
202
            'Meta': {'object_name': 'Token'},
 
203
            'callback': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
 
204
            'callback_confirmed': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
 
205
            'consumer': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['piston.Consumer']"}),
 
206
            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
 
207
            'is_approved': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
 
208
            'key': ('django.db.models.fields.CharField', [], {'max_length': '18'}),
 
209
            'secret': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
 
210
            'timestamp': ('django.db.models.fields.IntegerField', [], {'default': '1351767230L'}),
 
211
            'token_type': ('django.db.models.fields.IntegerField', [], {}),
 
212
            'user': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tokens'", 'null': 'True', 'to': "orm['auth.User']"}),
 
213
            'verifier': ('django.db.models.fields.CharField', [], {'max_length': '10'})
 
214
        }
 
215
    }
 
216
 
 
217
    complete_apps = ['maasserver']
 
218
    symmetrical = True