source: asadb/groups/migrations/0008_add_statusy_stuff_data.py

space-accessstablestage
Last change on this file was 7d43381, checked in by Alex Dehnert <adehnert@…>, 13 years ago

List the GSC funding board list of groups

  • Property mode set to 100644
File size: 13.5 KB
Line 
1# encoding: utf-8
2import datetime
3from south.db import db
4from south.v2 import DataMigration
5from django.db import models
6
7class Migration(DataMigration):
8
9    classes = [
10        ('Sponsored',   'sponsored',    True,   "Sponsored groups receive support (such as funding or space) from a departmental or similar entity.", ),
11        ('MIT-funded',  'mit-funded',   True,   "MIT-funded groups are eligible for funding from the UA or GSC funding boards.", ),
12        ('Unfunded',    'unfunded',     True,   "Unfunded groups are ineligible for funding from the UA and GSC funding boards and office space.", ),
13        ('Club Sport',  'club-sport',   True,   "Club Sports are recognized and funded through the Club Sports Council.", ),
14        ('Dorm/FSILG',  'dfsilg',       False,  "Dorm/FSILGs provide housing for MIT students, with varying degrees of Institute recognition/support.", ),
15    ]
16
17    statuses = [
18        ('Active',      'active',       True,   "Active groups are fully recognized and operational groups.", ),
19        ('Suspended',   'suspended',    True,   "Suspended groups have generally been temporarily semi-derecognized and will be fully derecognized if no further action is taken.", ),
20        ('Derecognized','derecognized', False,  "Derecognized groups are no longer extant.", ),
21    ]
22
23    funding = [
24        ('undergraduate',   'undergrad',    'finboard@mit.edu', 'finboard-groups-only', ),
25        ('graduate',        'grad',         'gsc-funding@mit.edu', "gsc-fb-", ),
26        ('sports council',  'csc',          'csc-officers@mit.edu', "", ),
27    ]
28
29    def forwards(self, orm):
30        "Write your forwards methods here."
31        for name, slug, gets_publicity, desc in self.classes:
32            group_class = orm.GroupClass(name=name, slug=slug, gets_publicity=gets_publicity, description=desc)
33            group_class.save()
34
35        for name, slug, is_active, desc in self.statuses:
36            group_status = orm.GroupStatus(name=name, slug=slug, is_active=is_active, description=desc)
37            group_status.save()
38
39        for name, slug, contact_email, funding_list in self.funding:
40            group_funder = orm.GroupFunding(name=name, slug=slug, contact_email=contact_email, funding_list=funding_list, )
41            group_funder.save()
42
43        for group in orm.Group.objects.all():
44            if group.group_class_id == -1:
45                group.group_class = orm.GroupClass.objects.get(slug='unfunded')
46                if group.activity_category:
47                    if group.activity_category.name == "Athletic":
48                        group.group_class = orm.GroupClass.objects.get(slug='club-sport')
49                    elif group.activity_category.name == "Dorm/FSILG":
50                        group.group_class = orm.GroupClass.objects.get(slug='dfsilg')
51            if group.group_status_id == -1:
52                group.group_status = orm.GroupStatus.objects.get(slug='active')
53            group.save()
54
55
56    def backwards(self, orm):
57        "Write your backwards methods here."
58        for name, slug, gets_publicity, desc in self.classes:
59            group_class = orm.GroupClass.objects.get(slug=slug)
60            group_class.delete()
61
62        for name, slug, is_active, desc in self.statuses:
63            group_status = orm.GroupStatus.objects.get(slug=slug)
64            group_status.delete()
65
66        for name, slug, contact_email, funding_list in self.funding:
67            group_funder = orm.GroupClass.objects.get(slug=slug)
68            group_funder.delete()
69
70
71    models = {
72        'auth.group': {
73            'Meta': {'object_name': 'Group'},
74            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
75            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
76            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
77        },
78        'auth.permission': {
79            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
80            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
81            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
82            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
83            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
84        },
85        'auth.user': {
86            'Meta': {'object_name': 'User'},
87            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
88            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
89            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
90            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
91            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
92            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
93            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
94            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
95            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
96            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
97            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
98            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
99            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
100        },
101        'contenttypes.contenttype': {
102            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
103            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
104            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
105            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
106            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
107        },
108        'groups.activitycategory': {
109            'Meta': {'object_name': 'ActivityCategory'},
110            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
111            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
112        },
113        'groups.athenamoiraaccount': {
114            'Meta': {'object_name': 'AthenaMoiraAccount'},
115            'account_class': ('django.db.models.fields.CharField', [], {'max_length': '10'}),
116            'add_date': ('django.db.models.fields.DateField', [], {}),
117            'del_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
118            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '45'}),
119            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
120            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '45'}),
121            'mit_id': ('django.db.models.fields.CharField', [], {'max_length': '15'}),
122            'mod_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
123            'mutable': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
124            'username': ('django.db.models.fields.CharField', [], {'max_length': '8'})
125        },
126        'groups.group': {
127            'Meta': {'ordering': "('name',)", 'object_name': 'Group'},
128            'abbreviation': ('django.db.models.fields.CharField', [], {'max_length': '10', 'blank': 'True'}),
129            'activity_category': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.ActivityCategory']", 'null': 'True', 'blank': 'True'}),
130            'advisor_name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
131            'athena_locker': ('django.db.models.fields.CharField', [], {'max_length': '20', 'blank': 'True'}),
132            'constitution_url': ('django.db.models.fields.CharField', [], {'max_length': '200', 'blank': 'True'}),
133            'description': ('django.db.models.fields.TextField', [], {}),
134            'funding_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
135            'group_class': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupClass']"}),
136            'group_email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
137            'group_funding': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupFunding']", 'null': 'True', 'blank': 'True'}),
138            'group_status': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupStatus']"}),
139            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
140            'main_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
141            'meeting_times': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
142            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
143            'num_community': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
144            'num_grads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
145            'num_other': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
146            'num_undergrads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
147            'officer_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
148            'recognition_date': ('django.db.models.fields.DateField', [], {}),
149            'update_date': ('django.db.models.fields.DateTimeField', [], {}),
150            'updater': ('django.db.models.fields.CharField', [], {'max_length': '30'}),
151            'website_url': ('django.db.models.fields.URLField', [], {'max_length': '200'})
152        },
153        'groups.groupclass': {
154            'Meta': {'object_name': 'GroupClass'},
155            'description': ('django.db.models.fields.TextField', [], {}),
156            'gets_publicity': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
157            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
158            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
159            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
160        },
161        'groups.groupfunding': {
162            'Meta': {'object_name': 'GroupFunding'},
163            'contact_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
164            'funding_list': ('django.db.models.fields.CharField', [], {'max_length': '32', 'blank': 'True'}),
165            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
166            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
167            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
168        },
169        'groups.groupstatus': {
170            'Meta': {'object_name': 'GroupStatus'},
171            'description': ('django.db.models.fields.TextField', [], {}),
172            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
173            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
174            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
175            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
176        },
177        'groups.officeholder': {
178            'Meta': {'object_name': 'OfficeHolder'},
179            'end_time': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(9999, 12, 31, 23, 59, 59, 999999)'}),
180            'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']"}),
181            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
182            'person': ('django.db.models.fields.CharField', [], {'max_length': '30'}),
183            'role': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.OfficerRole']"}),
184            'start_time': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'})
185        },
186        'groups.officerrole': {
187            'Meta': {'object_name': 'OfficerRole'},
188            'description': ('django.db.models.fields.TextField', [], {}),
189            'display_name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
190            'grant_user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['auth.User']", 'null': 'True'}),
191            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
192            'max_count': ('django.db.models.fields.IntegerField', [], {'default': '10000'}),
193            'require_student': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
194            'slug': ('django.db.models.fields.SlugField', [], {'max_length': '50', 'db_index': 'True'})
195        }
196    }
197
198    complete_apps = ['groups']
Note: See TracBrowser for help on using the repository browser.