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 | import forms.models |
---|
8 | import groups.models |
---|
9 | |
---|
10 | class Migration(DataMigration): |
---|
11 | |
---|
12 | def forwards(self, orm): |
---|
13 | "Write your forwards methods here." |
---|
14 | cycle = orm.GroupConfirmationCycle() |
---|
15 | cycle.name = "Fall 2011" |
---|
16 | cycle.slug = "2011-fall" |
---|
17 | cycle.save() |
---|
18 | |
---|
19 | confirmations = orm.PersonMembershipUpdate.objects.filter(deleted__isnull=True) |
---|
20 | found_people = {} |
---|
21 | replacements = {} |
---|
22 | for confirmation in confirmations: |
---|
23 | username = confirmation.username |
---|
24 | if username in replacements: |
---|
25 | for group in confirmation.groups.all(): |
---|
26 | replacements[username].groups.add(group) |
---|
27 | confirmation.deleted = datetime.datetime.now() |
---|
28 | confirmation.save() |
---|
29 | elif username in found_people: |
---|
30 | replacement = orm.PersonMembershipUpdate() |
---|
31 | replacements[username] = replacement |
---|
32 | replacement.update_time = datetime.datetime.now() |
---|
33 | replacement.username = username |
---|
34 | replacement.cycle = cycle |
---|
35 | replacement.deleted = None |
---|
36 | replacement.save() |
---|
37 | for group in found_people[username].groups.all(): |
---|
38 | replacement.groups.add(group) |
---|
39 | for group in confirmation.groups.all(): |
---|
40 | replacement.groups.add(group) |
---|
41 | found_people[username].deleted = datetime.datetime.now() |
---|
42 | found_people[username].save() |
---|
43 | del found_people[username] |
---|
44 | confirmation.deleted = datetime.datetime.now() |
---|
45 | confirmation.save() |
---|
46 | else: |
---|
47 | found_people[username] = confirmation |
---|
48 | for username, confirmation in replacements.items(): |
---|
49 | confirmation.save() |
---|
50 | |
---|
51 | confirmations = orm.PersonMembershipUpdate.objects.filter(deleted__isnull=True, valid=forms.models.VALID_UNSET) |
---|
52 | accounts = groups.models.AthenaMoiraAccount |
---|
53 | for confirmation in confirmations: |
---|
54 | try: |
---|
55 | person = accounts.active_accounts.get(username=confirmation.username) |
---|
56 | if person.is_student(): |
---|
57 | confirmation.valid = forms.models.VALID_AUTOVALIDATED |
---|
58 | else: |
---|
59 | confirmation.valid = forms.models.VALID_AUTOREJECTED |
---|
60 | |
---|
61 | except accounts.DoesNotExist: |
---|
62 | print "Could not find %s; rejecting" % (confirmation.username, ) |
---|
63 | confirmation.valid = forms.models.VALID_AUTOREJECTED |
---|
64 | confirmation.save() |
---|
65 | |
---|
66 | |
---|
67 | def backwards(self, orm): |
---|
68 | "Write your backwards methods here." |
---|
69 | |
---|
70 | |
---|
71 | models = { |
---|
72 | 'forms.fysm': { |
---|
73 | 'Meta': {'object_name': 'FYSM'}, |
---|
74 | 'categories': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['forms.FYSMCategory']", 'symmetrical': 'False', 'blank': 'True'}), |
---|
75 | 'contact_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
---|
76 | 'description': ('django.db.models.fields.TextField', [], {}), |
---|
77 | 'display_name': ('django.db.models.fields.CharField', [], {'max_length': '50'}), |
---|
78 | 'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']"}), |
---|
79 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
80 | 'join_preview': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forms.PagePreview']", 'null': 'True'}), |
---|
81 | 'join_url': ('django.db.models.fields.URLField', [], {'max_length': '200'}), |
---|
82 | 'logo': ('django.db.models.fields.files.ImageField', [], {'max_length': '100', 'blank': 'True'}), |
---|
83 | 'slide': ('django.db.models.fields.files.ImageField', [], {'default': "''", 'max_length': '100'}), |
---|
84 | 'tags': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}), |
---|
85 | 'website': ('django.db.models.fields.URLField', [], {'max_length': '200'}), |
---|
86 | 'year': ('django.db.models.fields.IntegerField', [], {}) |
---|
87 | }, |
---|
88 | 'forms.fysmcategory': { |
---|
89 | 'Meta': {'ordering': "['name']", 'object_name': 'FYSMCategory'}, |
---|
90 | 'blurb': ('django.db.models.fields.TextField', [], {}), |
---|
91 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
92 | 'name': ('django.db.models.fields.CharField', [], {'max_length': '25'}), |
---|
93 | 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '50', 'db_index': 'True'}) |
---|
94 | }, |
---|
95 | 'forms.fysmview': { |
---|
96 | 'Meta': {'object_name': 'FYSMView'}, |
---|
97 | 'fysm': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forms.FYSM']", 'null': 'True', 'blank': 'True'}), |
---|
98 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
99 | 'page': ('django.db.models.fields.CharField', [], {'max_length': '20', 'blank': 'True'}), |
---|
100 | 'referer': ('django.db.models.fields.URLField', [], {'max_length': '200', 'null': 'True'}), |
---|
101 | 'source_ip': ('django.db.models.fields.IPAddressField', [], {'max_length': '15'}), |
---|
102 | 'source_user': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
---|
103 | 'user_agent': ('django.db.models.fields.CharField', [], {'max_length': '255'}), |
---|
104 | 'when': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
---|
105 | 'year': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}) |
---|
106 | }, |
---|
107 | 'forms.groupconfirmationcycle': { |
---|
108 | 'Meta': {'object_name': 'GroupConfirmationCycle'}, |
---|
109 | 'create_date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
---|
110 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
111 | 'name': ('django.db.models.fields.CharField', [], {'max_length': '30'}), |
---|
112 | 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '50', 'db_index': 'True'}) |
---|
113 | }, |
---|
114 | 'forms.groupmembershipupdate': { |
---|
115 | 'Meta': {'object_name': 'GroupMembershipUpdate'}, |
---|
116 | 'email_preface': ('django.db.models.fields.TextField', [], {'blank': 'True'}), |
---|
117 | 'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']"}), |
---|
118 | 'group_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
---|
119 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
120 | 'membership_definition': ('django.db.models.fields.TextField', [], {}), |
---|
121 | 'membership_list': ('django.db.models.fields.TextField', [], {}), |
---|
122 | 'no_discrimination': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
---|
123 | 'no_hazing': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
---|
124 | 'num_alum': ('django.db.models.fields.IntegerField', [], {}), |
---|
125 | 'num_grads': ('django.db.models.fields.IntegerField', [], {}), |
---|
126 | 'num_other': ('django.db.models.fields.IntegerField', [], {}), |
---|
127 | 'num_other_affiliate': ('django.db.models.fields.IntegerField', [], {}), |
---|
128 | 'num_undergrads': ('django.db.models.fields.IntegerField', [], {}), |
---|
129 | 'officer_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
---|
130 | 'update_time': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1970, 1, 1, 0, 0)'}), |
---|
131 | 'updater_name': ('django.db.models.fields.CharField', [], {'max_length': '30'}), |
---|
132 | 'updater_title': ('django.db.models.fields.CharField', [], {'max_length': '30'}) |
---|
133 | }, |
---|
134 | 'forms.pagepreview': { |
---|
135 | 'Meta': {'object_name': 'PagePreview'}, |
---|
136 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
137 | 'image': ('django.db.models.fields.files.ImageField', [], {'max_length': '100', 'blank': 'True'}), |
---|
138 | 'update_time': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1970, 1, 1, 0, 0)'}), |
---|
139 | 'url': ('django.db.models.fields.URLField', [], {'max_length': '200'}) |
---|
140 | }, |
---|
141 | 'forms.personmembershipupdate': { |
---|
142 | 'Meta': {'object_name': 'PersonMembershipUpdate'}, |
---|
143 | 'cycle': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forms.GroupConfirmationCycle']"}), |
---|
144 | 'deleted': ('django.db.models.fields.DateTimeField', [], {'default': 'None', 'null': 'True'}), |
---|
145 | 'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['groups.Group']", 'symmetrical': 'False'}), |
---|
146 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
147 | 'update_time': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(1970, 1, 1, 0, 0)'}), |
---|
148 | 'username': ('django.db.models.fields.CharField', [], {'max_length': '30'}), |
---|
149 | 'valid': ('django.db.models.fields.IntegerField', [], {'default': '0'}) |
---|
150 | }, |
---|
151 | 'groups.activitycategory': { |
---|
152 | 'Meta': {'object_name': 'ActivityCategory'}, |
---|
153 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
154 | 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}) |
---|
155 | }, |
---|
156 | 'groups.group': { |
---|
157 | 'Meta': {'ordering': "('name',)", 'object_name': 'Group'}, |
---|
158 | 'abbreviation': ('django.db.models.fields.CharField', [], {'max_length': '10', 'blank': 'True'}), |
---|
159 | 'activity_category': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.ActivityCategory']", 'null': 'True', 'blank': 'True'}), |
---|
160 | 'advisor_name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}), |
---|
161 | 'athena_locker': ('django.db.models.fields.CharField', [], {'max_length': '20', 'blank': 'True'}), |
---|
162 | 'constitution_url': ('django.db.models.fields.CharField', [], {'max_length': '200', 'blank': 'True'}), |
---|
163 | 'description': ('django.db.models.fields.TextField', [], {}), |
---|
164 | 'funding_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), |
---|
165 | 'group_class': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupClass']"}), |
---|
166 | 'group_email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}), |
---|
167 | 'group_funding': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupFunding']", 'null': 'True', 'blank': 'True'}), |
---|
168 | 'group_status': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupStatus']"}), |
---|
169 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
170 | 'main_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), |
---|
171 | 'meeting_times': ('django.db.models.fields.TextField', [], {'blank': 'True'}), |
---|
172 | 'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
---|
173 | 'num_community': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), |
---|
174 | 'num_grads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), |
---|
175 | 'num_other': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), |
---|
176 | 'num_undergrads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), |
---|
177 | 'officer_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
---|
178 | 'recognition_date': ('django.db.models.fields.DateField', [], {}), |
---|
179 | 'update_date': ('django.db.models.fields.DateTimeField', [], {}), |
---|
180 | 'updater': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}), |
---|
181 | 'website_url': ('django.db.models.fields.URLField', [], {'max_length': '200'}) |
---|
182 | }, |
---|
183 | 'groups.groupclass': { |
---|
184 | 'Meta': {'object_name': 'GroupClass'}, |
---|
185 | 'description': ('django.db.models.fields.TextField', [], {}), |
---|
186 | 'gets_publicity': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
---|
187 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
188 | 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}), |
---|
189 | 'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'}) |
---|
190 | }, |
---|
191 | 'groups.groupfunding': { |
---|
192 | 'Meta': {'object_name': 'GroupFunding'}, |
---|
193 | 'contact_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
---|
194 | 'funding_list': ('django.db.models.fields.CharField', [], {'max_length': '32', 'blank': 'True'}), |
---|
195 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
196 | 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}), |
---|
197 | 'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'}) |
---|
198 | }, |
---|
199 | 'groups.groupstatus': { |
---|
200 | 'Meta': {'object_name': 'GroupStatus'}, |
---|
201 | 'description': ('django.db.models.fields.TextField', [], {}), |
---|
202 | 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
---|
203 | 'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), |
---|
204 | 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}), |
---|
205 | 'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'}) |
---|
206 | } |
---|
207 | } |
---|
208 | |
---|
209 | complete_apps = ['forms'] |
---|