Revision 76c68fd6
b/snf-astakos-app/astakos/im/forms.py | ||
---|---|---|
493 | 493 |
issue_date = forms.DateField(widget=SelectDateWidget()) |
494 | 494 |
expiration_date = forms.DateField(widget=SelectDateWidget()) |
495 | 495 |
kind = forms.ModelChoiceField(queryset=GroupKind.objects.all(), empty_label=None) |
496 |
name = forms.URLField() |
|
496 | 497 |
|
497 | 498 |
class Meta: |
498 | 499 |
model = AstakosGroup |
499 | 500 |
|
500 | 501 |
def __init__(self, *args, **kwargs): |
501 | 502 |
super(AstakosGroupCreationForm, self).__init__(*args, **kwargs) |
502 |
self.fields.keyOrder = ['kind', 'name', 'identifier', 'desc', 'issue_date',
|
|
503 |
self.fields.keyOrder = ['kind', 'name', 'desc', 'issue_date', |
|
503 | 504 |
'expiration_date', 'estimated_participants', |
504 | 505 |
'moderatation_enabled'] |
505 | 506 |
|
... | ... | |
508 | 509 |
if commit: |
509 | 510 |
g.save() |
510 | 511 |
g.owner = [request.user] |
511 |
g.approve_member(request.user) |
|
512 |
# g.approve_member(request.user)
|
|
512 | 513 |
return g |
513 | 514 |
|
514 | 515 |
return AstakosGroupCreationForm |
b/snf-astakos-app/astakos/im/migrations/0015_auto__add_groupkind__add_astakosgroup__add_resourcemetadata__add_astak.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 model 'GroupKind' |
|
12 |
db.create_table('im_groupkind', ( |
|
13 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
14 |
('name', self.gf('django.db.models.fields.CharField')(unique=True, max_length=255, db_index=True)), |
|
15 |
)) |
|
16 |
db.send_create_signal('im', ['GroupKind']) |
|
17 |
|
|
18 |
# Adding model 'AstakosGroup' |
|
19 |
db.create_table('im_astakosgroup', ( |
|
20 |
('group_ptr', self.gf('django.db.models.fields.related.OneToOneField')(to=orm['auth.Group'], unique=True, primary_key=True)), |
|
21 |
('kind', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.GroupKind'])), |
|
22 |
('desc', self.gf('django.db.models.fields.TextField')(null=True)), |
|
23 |
('creation_date', self.gf('django.db.models.fields.DateTimeField')(default=datetime.datetime(2012, 8, 3, 11, 26, 47, 642626))), |
|
24 |
('issue_date', self.gf('django.db.models.fields.DateTimeField')(null=True)), |
|
25 |
('expiration_date', self.gf('django.db.models.fields.DateTimeField')(null=True)), |
|
26 |
('moderatation_enabled', self.gf('django.db.models.fields.BooleanField')(default=False)), |
|
27 |
('approval_date', self.gf('django.db.models.fields.DateTimeField')(null=True, blank=True)), |
|
28 |
('estimated_participants', self.gf('django.db.models.fields.PositiveIntegerField')(null=True)), |
|
29 |
)) |
|
30 |
db.send_create_signal('im', ['AstakosGroup']) |
|
31 |
|
|
32 |
# Adding model 'ResourceMetadata' |
|
33 |
db.create_table('im_resourcemetadata', ( |
|
34 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
35 |
('key', self.gf('django.db.models.fields.CharField')(unique=True, max_length=255, db_index=True)), |
|
36 |
('value', self.gf('django.db.models.fields.CharField')(max_length=255)), |
|
37 |
)) |
|
38 |
db.send_create_signal('im', ['ResourceMetadata']) |
|
39 |
|
|
40 |
# Adding model 'AstakosGroupQuota' |
|
41 |
db.create_table('im_astakosgroupquota', ( |
|
42 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
43 |
('limit', self.gf('django.db.models.fields.PositiveIntegerField')()), |
|
44 |
('resource', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.Resource'])), |
|
45 |
('group', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosGroup'], blank=True)), |
|
46 |
)) |
|
47 |
db.send_create_signal('im', ['AstakosGroupQuota']) |
|
48 |
|
|
49 |
# Adding unique constraint on 'AstakosGroupQuota', fields ['resource', 'group'] |
|
50 |
db.create_unique('im_astakosgroupquota', ['resource_id', 'group_id']) |
|
51 |
|
|
52 |
# Adding model 'Resource' |
|
53 |
db.create_table('im_resource', ( |
|
54 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
55 |
('name', self.gf('django.db.models.fields.CharField')(unique=True, max_length=255, db_index=True)), |
|
56 |
('service', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.Service'])), |
|
57 |
)) |
|
58 |
db.send_create_signal('im', ['Resource']) |
|
59 |
|
|
60 |
# Adding M2M table for field meta on 'Resource' |
|
61 |
db.create_table('im_resource_meta', ( |
|
62 |
('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)), |
|
63 |
('resource', models.ForeignKey(orm['im.resource'], null=False)), |
|
64 |
('resourcemetadata', models.ForeignKey(orm['im.resourcemetadata'], null=False)) |
|
65 |
)) |
|
66 |
db.create_unique('im_resource_meta', ['resource_id', 'resourcemetadata_id']) |
|
67 |
|
|
68 |
# Adding model 'Membership' |
|
69 |
db.create_table('im_membership', ( |
|
70 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
71 |
('person', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosUser'])), |
|
72 |
('group', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosGroup'])), |
|
73 |
('date_requested', self.gf('django.db.models.fields.DateField')(default=datetime.datetime(2012, 8, 3, 11, 26, 47, 646518))), |
|
74 |
('date_joined', self.gf('django.db.models.fields.DateField')(null=True, db_index=True)), |
|
75 |
)) |
|
76 |
db.send_create_signal('im', ['Membership']) |
|
77 |
|
|
78 |
# Adding unique constraint on 'Membership', fields ['person', 'group'] |
|
79 |
db.create_unique('im_membership', ['person_id', 'group_id']) |
|
80 |
|
|
81 |
# Adding model 'AstakosUserQuota' |
|
82 |
db.create_table('im_astakosuserquota', ( |
|
83 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
84 |
('limit', self.gf('django.db.models.fields.PositiveIntegerField')()), |
|
85 |
('resource', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.Resource'])), |
|
86 |
('user', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosUser'])), |
|
87 |
)) |
|
88 |
db.send_create_signal('im', ['AstakosUserQuota']) |
|
89 |
|
|
90 |
# Adding unique constraint on 'AstakosUserQuota', fields ['resource', 'user'] |
|
91 |
db.create_unique('im_astakosuserquota', ['resource_id', 'user_id']) |
|
92 |
|
|
93 |
# Adding index on 'Service', fields ['name'] |
|
94 |
db.create_index('im_service', ['name']) |
|
95 |
|
|
96 |
# Adding M2M table for field owner on 'AstakosUser' |
|
97 |
db.create_table('im_astakosuser_owner', ( |
|
98 |
('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)), |
|
99 |
('astakosuser', models.ForeignKey(orm['im.astakosuser'], null=False)), |
|
100 |
('astakosgroup', models.ForeignKey(orm['im.astakosgroup'], null=False)) |
|
101 |
)) |
|
102 |
db.create_unique('im_astakosuser_owner', ['astakosuser_id', 'astakosgroup_id']) |
|
103 |
|
|
104 |
|
|
105 |
def backwards(self, orm): |
|
106 |
|
|
107 |
# Removing index on 'Service', fields ['name'] |
|
108 |
db.delete_index('im_service', ['name']) |
|
109 |
|
|
110 |
# Removing unique constraint on 'AstakosUserQuota', fields ['resource', 'user'] |
|
111 |
db.delete_unique('im_astakosuserquota', ['resource_id', 'user_id']) |
|
112 |
|
|
113 |
# Removing unique constraint on 'Membership', fields ['person', 'group'] |
|
114 |
db.delete_unique('im_membership', ['person_id', 'group_id']) |
|
115 |
|
|
116 |
# Removing unique constraint on 'AstakosGroupQuota', fields ['resource', 'group'] |
|
117 |
db.delete_unique('im_astakosgroupquota', ['resource_id', 'group_id']) |
|
118 |
|
|
119 |
# Deleting model 'GroupKind' |
|
120 |
db.delete_table('im_groupkind') |
|
121 |
|
|
122 |
# Deleting model 'AstakosGroup' |
|
123 |
db.delete_table('im_astakosgroup') |
|
124 |
|
|
125 |
# Deleting model 'ResourceMetadata' |
|
126 |
db.delete_table('im_resourcemetadata') |
|
127 |
|
|
128 |
# Deleting model 'AstakosGroupQuota' |
|
129 |
db.delete_table('im_astakosgroupquota') |
|
130 |
|
|
131 |
# Deleting model 'Resource' |
|
132 |
db.delete_table('im_resource') |
|
133 |
|
|
134 |
# Removing M2M table for field meta on 'Resource' |
|
135 |
db.delete_table('im_resource_meta') |
|
136 |
|
|
137 |
# Deleting model 'Membership' |
|
138 |
db.delete_table('im_membership') |
|
139 |
|
|
140 |
# Deleting model 'AstakosUserQuota' |
|
141 |
db.delete_table('im_astakosuserquota') |
|
142 |
|
|
143 |
# Removing M2M table for field owner on 'AstakosUser' |
|
144 |
db.delete_table('im_astakosuser_owner') |
|
145 |
|
|
146 |
|
|
147 |
models = { |
|
148 |
'auth.group': { |
|
149 |
'Meta': {'object_name': 'Group'}, |
|
150 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
151 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}), |
|
152 |
'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}) |
|
153 |
}, |
|
154 |
'auth.permission': { |
|
155 |
'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'}, |
|
156 |
'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
157 |
'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}), |
|
158 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
159 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}) |
|
160 |
}, |
|
161 |
'auth.user': { |
|
162 |
'Meta': {'object_name': 'User'}, |
|
163 |
'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
|
164 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}), |
|
165 |
'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
|
166 |
'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}), |
|
167 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
168 |
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), |
|
169 |
'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
170 |
'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
171 |
'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
|
172 |
'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
|
173 |
'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}), |
|
174 |
'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}), |
|
175 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'}) |
|
176 |
}, |
|
177 |
'contenttypes.contenttype': { |
|
178 |
'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"}, |
|
179 |
'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
180 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
181 |
'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
182 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}) |
|
183 |
}, |
|
184 |
'im.additionalmail': { |
|
185 |
'Meta': {'object_name': 'AdditionalMail'}, |
|
186 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
|
187 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
188 |
'owner': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
189 |
}, |
|
190 |
'im.approvalterms': { |
|
191 |
'Meta': {'object_name': 'ApprovalTerms'}, |
|
192 |
'date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 3, 11, 26, 47, 648667)', 'db_index': 'True'}), |
|
193 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
194 |
'location': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
|
195 |
}, |
|
196 |
'im.astakosgroup': { |
|
197 |
'Meta': {'object_name': 'AstakosGroup', '_ormbases': ['auth.Group']}, |
|
198 |
'approval_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
199 |
'creation_date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 3, 11, 26, 47, 642626)'}), |
|
200 |
'desc': ('django.db.models.fields.TextField', [], {'null': 'True'}), |
|
201 |
'estimated_participants': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}), |
|
202 |
'expiration_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
203 |
'group_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.Group']", 'unique': 'True', 'primary_key': 'True'}), |
|
204 |
'issue_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
205 |
'kind': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.GroupKind']"}), |
|
206 |
'moderatation_enabled': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
207 |
'policy': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.AstakosGroupQuota']", 'blank': 'True'}) |
|
208 |
}, |
|
209 |
'im.astakosgroupquota': { |
|
210 |
'Meta': {'unique_together': "(('resource', 'group'),)", 'object_name': 'AstakosGroupQuota'}, |
|
211 |
'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosGroup']", 'blank': 'True'}), |
|
212 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
213 |
'limit': ('django.db.models.fields.PositiveIntegerField', [], {}), |
|
214 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}) |
|
215 |
}, |
|
216 |
'im.astakosuser': { |
|
217 |
'Meta': {'unique_together': "(('provider', 'third_party_identifier'),)", 'object_name': 'AstakosUser', '_ormbases': ['auth.User']}, |
|
218 |
'activation_sent': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
219 |
'affiliation': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}), |
|
220 |
'astakos_groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.AstakosGroup']", 'symmetrical': 'False', 'through': "orm['im.Membership']", 'blank': 'True'}), |
|
221 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
|
222 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
223 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
224 |
'date_signed_terms': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
225 |
'email_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
226 |
'has_credits': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
227 |
'has_signed_terms': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
228 |
'invitations': ('django.db.models.fields.IntegerField', [], {'default': '100'}), |
|
229 |
'is_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
230 |
'level': ('django.db.models.fields.IntegerField', [], {'default': '0'}), |
|
231 |
'owner': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'owner'", 'null': 'True', 'to': "orm['im.AstakosGroup']"}), |
|
232 |
'policy': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.AstakosUserQuota']", 'symmetrical': 'False'}), |
|
233 |
'provider': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}), |
|
234 |
'third_party_identifier': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
|
235 |
'updated': ('django.db.models.fields.DateTimeField', [], {}), |
|
236 |
'user_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True', 'primary_key': 'True'}) |
|
237 |
}, |
|
238 |
'im.astakosuserquota': { |
|
239 |
'Meta': {'unique_together': "(('resource', 'user'),)", 'object_name': 'AstakosUserQuota'}, |
|
240 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
241 |
'limit': ('django.db.models.fields.PositiveIntegerField', [], {}), |
|
242 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}), |
|
243 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
244 |
}, |
|
245 |
'im.emailchange': { |
|
246 |
'Meta': {'object_name': 'EmailChange'}, |
|
247 |
'activation_key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}), |
|
248 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
249 |
'new_email_address': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
|
250 |
'requested_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 3, 11, 26, 47, 650373)'}), |
|
251 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'emailchange_user'", 'unique': 'True', 'to': "orm['im.AstakosUser']"}) |
|
252 |
}, |
|
253 |
'im.groupkind': { |
|
254 |
'Meta': {'object_name': 'GroupKind'}, |
|
255 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
256 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}) |
|
257 |
}, |
|
258 |
'im.invitation': { |
|
259 |
'Meta': {'object_name': 'Invitation'}, |
|
260 |
'code': ('django.db.models.fields.BigIntegerField', [], {'db_index': 'True'}), |
|
261 |
'consumed': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
262 |
'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}), |
|
263 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
264 |
'inviter': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'invitations_sent'", 'null': 'True', 'to': "orm['im.AstakosUser']"}), |
|
265 |
'is_consumed': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
266 |
'realname': ('django.db.models.fields.CharField', [], {'max_length': '255'}), |
|
267 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}) |
|
268 |
}, |
|
269 |
'im.membership': { |
|
270 |
'Meta': {'unique_together': "(('person', 'group'),)", 'object_name': 'Membership'}, |
|
271 |
'date_joined': ('django.db.models.fields.DateField', [], {'null': 'True', 'db_index': 'True'}), |
|
272 |
'date_requested': ('django.db.models.fields.DateField', [], {'default': 'datetime.datetime(2012, 8, 3, 11, 26, 47, 646518)'}), |
|
273 |
'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosGroup']"}), |
|
274 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
275 |
'person': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
276 |
}, |
|
277 |
'im.resource': { |
|
278 |
'Meta': {'object_name': 'Resource'}, |
|
279 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
280 |
'meta': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.ResourceMetadata']", 'symmetrical': 'False'}), |
|
281 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
282 |
'service': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Service']"}) |
|
283 |
}, |
|
284 |
'im.resourcemetadata': { |
|
285 |
'Meta': {'object_name': 'ResourceMetadata'}, |
|
286 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
287 |
'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
288 |
'value': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
|
289 |
}, |
|
290 |
'im.service': { |
|
291 |
'Meta': {'object_name': 'Service'}, |
|
292 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
|
293 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
294 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
295 |
'icon': ('django.db.models.fields.FilePathField', [], {'max_length': '100', 'blank': 'True'}), |
|
296 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
297 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
298 |
'url': ('django.db.models.fields.FilePathField', [], {'max_length': '100'}) |
|
299 |
} |
|
300 |
} |
|
301 |
|
|
302 |
complete_apps = ['im'] |
/dev/null | ||
---|---|---|
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 model 'GroupKind' |
|
12 |
db.create_table('im_groupkind', ( |
|
13 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
14 |
('name', self.gf('django.db.models.fields.CharField')(unique=True, max_length=255, db_index=True)), |
|
15 |
)) |
|
16 |
db.send_create_signal('im', ['GroupKind']) |
|
17 |
|
|
18 |
# Adding model 'AstakosGroup' |
|
19 |
db.create_table('im_astakosgroup', ( |
|
20 |
('group_ptr', self.gf('django.db.models.fields.related.OneToOneField')(to=orm['auth.Group'], unique=True, primary_key=True)), |
|
21 |
('kind', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.GroupKind'])), |
|
22 |
('desc', self.gf('django.db.models.fields.TextField')(null=True)), |
|
23 |
('identifier', self.gf('django.db.models.fields.URLField')(default='', unique=True, max_length=200, db_index=True)), |
|
24 |
('creation_date', self.gf('django.db.models.fields.DateTimeField')(default=datetime.datetime(2012, 8, 2, 22, 23, 54, 131886))), |
|
25 |
('issue_date', self.gf('django.db.models.fields.DateTimeField')(null=True)), |
|
26 |
('expiration_date', self.gf('django.db.models.fields.DateTimeField')(null=True)), |
|
27 |
('moderatation_enabled', self.gf('django.db.models.fields.BooleanField')(default=False)), |
|
28 |
('approval_date', self.gf('django.db.models.fields.DateTimeField')(null=True, blank=True)), |
|
29 |
('estimated_participants', self.gf('django.db.models.fields.PositiveIntegerField')(null=True)), |
|
30 |
)) |
|
31 |
db.send_create_signal('im', ['AstakosGroup']) |
|
32 |
|
|
33 |
# Adding model 'ResourceMetadata' |
|
34 |
db.create_table('im_resourcemetadata', ( |
|
35 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
36 |
('key', self.gf('django.db.models.fields.CharField')(unique=True, max_length=255, db_index=True)), |
|
37 |
('value', self.gf('django.db.models.fields.CharField')(max_length=255)), |
|
38 |
)) |
|
39 |
db.send_create_signal('im', ['ResourceMetadata']) |
|
40 |
|
|
41 |
# Adding model 'Resource' |
|
42 |
db.create_table('im_resource', ( |
|
43 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
44 |
('name', self.gf('django.db.models.fields.CharField')(unique=True, max_length=255, db_index=True)), |
|
45 |
('service', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.Service'])), |
|
46 |
)) |
|
47 |
db.send_create_signal('im', ['Resource']) |
|
48 |
|
|
49 |
# Adding M2M table for field meta on 'Resource' |
|
50 |
db.create_table('im_resource_meta', ( |
|
51 |
('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)), |
|
52 |
('resource', models.ForeignKey(orm['im.resource'], null=False)), |
|
53 |
('resourcemetadata', models.ForeignKey(orm['im.resourcemetadata'], null=False)) |
|
54 |
)) |
|
55 |
db.create_unique('im_resource_meta', ['resource_id', 'resourcemetadata_id']) |
|
56 |
|
|
57 |
# Adding model 'AstakosUserQuota' |
|
58 |
db.create_table('im_astakosuserquota', ( |
|
59 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
60 |
('limit', self.gf('django.db.models.fields.PositiveIntegerField')()), |
|
61 |
('resource', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.Resource'])), |
|
62 |
('user', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosUser'])), |
|
63 |
)) |
|
64 |
db.send_create_signal('im', ['AstakosUserQuota']) |
|
65 |
|
|
66 |
# Adding model 'Membership' |
|
67 |
db.create_table('im_membership', ( |
|
68 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
69 |
('person', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosUser'])), |
|
70 |
('group', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosGroup'])), |
|
71 |
('date_requested', self.gf('django.db.models.fields.DateField')(default=datetime.datetime(2012, 8, 2, 22, 23, 54, 135644))), |
|
72 |
('date_joined', self.gf('django.db.models.fields.DateField')(null=True, db_index=True)), |
|
73 |
)) |
|
74 |
db.send_create_signal('im', ['Membership']) |
|
75 |
|
|
76 |
# Adding unique constraint on 'Membership', fields ['person', 'group'] |
|
77 |
db.create_unique('im_membership', ['person_id', 'group_id']) |
|
78 |
|
|
79 |
# Adding model 'AstakosGroupQuota' |
|
80 |
db.create_table('im_astakosgroupquota', ( |
|
81 |
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), |
|
82 |
('limit', self.gf('django.db.models.fields.PositiveIntegerField')()), |
|
83 |
('resource', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.Resource'])), |
|
84 |
('group', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['im.AstakosGroup'])), |
|
85 |
)) |
|
86 |
db.send_create_signal('im', ['AstakosGroupQuota']) |
|
87 |
|
|
88 |
# Adding index on 'Service', fields ['name'] |
|
89 |
db.create_index('im_service', ['name']) |
|
90 |
|
|
91 |
# Adding M2M table for field owner on 'AstakosUser' |
|
92 |
db.create_table('im_astakosuser_owner', ( |
|
93 |
('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)), |
|
94 |
('astakosuser', models.ForeignKey(orm['im.astakosuser'], null=False)), |
|
95 |
('astakosgroup', models.ForeignKey(orm['im.astakosgroup'], null=False)) |
|
96 |
)) |
|
97 |
db.create_unique('im_astakosuser_owner', ['astakosuser_id', 'astakosgroup_id']) |
|
98 |
|
|
99 |
|
|
100 |
def backwards(self, orm): |
|
101 |
|
|
102 |
# Removing index on 'Service', fields ['name'] |
|
103 |
db.delete_index('im_service', ['name']) |
|
104 |
|
|
105 |
# Removing unique constraint on 'Membership', fields ['person', 'group'] |
|
106 |
db.delete_unique('im_membership', ['person_id', 'group_id']) |
|
107 |
|
|
108 |
# Deleting model 'GroupKind' |
|
109 |
db.delete_table('im_groupkind') |
|
110 |
|
|
111 |
# Deleting model 'AstakosGroup' |
|
112 |
db.delete_table('im_astakosgroup') |
|
113 |
|
|
114 |
# Deleting model 'ResourceMetadata' |
|
115 |
db.delete_table('im_resourcemetadata') |
|
116 |
|
|
117 |
# Deleting model 'Resource' |
|
118 |
db.delete_table('im_resource') |
|
119 |
|
|
120 |
# Removing M2M table for field meta on 'Resource' |
|
121 |
db.delete_table('im_resource_meta') |
|
122 |
|
|
123 |
# Deleting model 'AstakosUserQuota' |
|
124 |
db.delete_table('im_astakosuserquota') |
|
125 |
|
|
126 |
# Deleting model 'Membership' |
|
127 |
db.delete_table('im_membership') |
|
128 |
|
|
129 |
# Deleting model 'AstakosGroupQuota' |
|
130 |
db.delete_table('im_astakosgroupquota') |
|
131 |
|
|
132 |
# Removing M2M table for field owner on 'AstakosUser' |
|
133 |
db.delete_table('im_astakosuser_owner') |
|
134 |
|
|
135 |
|
|
136 |
models = { |
|
137 |
'auth.group': { |
|
138 |
'Meta': {'object_name': 'Group'}, |
|
139 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
140 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}), |
|
141 |
'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}) |
|
142 |
}, |
|
143 |
'auth.permission': { |
|
144 |
'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'}, |
|
145 |
'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
146 |
'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}), |
|
147 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
148 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}) |
|
149 |
}, |
|
150 |
'auth.user': { |
|
151 |
'Meta': {'object_name': 'User'}, |
|
152 |
'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
|
153 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}), |
|
154 |
'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
|
155 |
'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}), |
|
156 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
157 |
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), |
|
158 |
'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
159 |
'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
160 |
'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
|
161 |
'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
|
162 |
'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}), |
|
163 |
'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}), |
|
164 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'}) |
|
165 |
}, |
|
166 |
'contenttypes.contenttype': { |
|
167 |
'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"}, |
|
168 |
'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
169 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
170 |
'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
171 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}) |
|
172 |
}, |
|
173 |
'im.additionalmail': { |
|
174 |
'Meta': {'object_name': 'AdditionalMail'}, |
|
175 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
|
176 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
177 |
'owner': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
178 |
}, |
|
179 |
'im.approvalterms': { |
|
180 |
'Meta': {'object_name': 'ApprovalTerms'}, |
|
181 |
'date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 2, 22, 23, 54, 137733)', 'db_index': 'True'}), |
|
182 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
183 |
'location': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
|
184 |
}, |
|
185 |
'im.astakosgroup': { |
|
186 |
'Meta': {'object_name': 'AstakosGroup', '_ormbases': ['auth.Group']}, |
|
187 |
'approval_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
188 |
'creation_date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 2, 22, 23, 54, 131886)'}), |
|
189 |
'desc': ('django.db.models.fields.TextField', [], {'null': 'True'}), |
|
190 |
'estimated_participants': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}), |
|
191 |
'expiration_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
192 |
'group_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.Group']", 'unique': 'True', 'primary_key': 'True'}), |
|
193 |
'identifier': ('django.db.models.fields.URLField', [], {'default': "''", 'unique': 'True', 'max_length': '200', 'db_index': 'True'}), |
|
194 |
'issue_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
195 |
'kind': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.GroupKind']"}), |
|
196 |
'moderatation_enabled': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
197 |
'policy': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.AstakosGroupQuota']", 'blank': 'True'}) |
|
198 |
}, |
|
199 |
'im.astakosgroupquota': { |
|
200 |
'Meta': {'object_name': 'AstakosGroupQuota'}, |
|
201 |
'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosGroup']"}), |
|
202 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
203 |
'limit': ('django.db.models.fields.PositiveIntegerField', [], {}), |
|
204 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}) |
|
205 |
}, |
|
206 |
'im.astakosuser': { |
|
207 |
'Meta': {'unique_together': "(('provider', 'third_party_identifier'),)", 'object_name': 'AstakosUser', '_ormbases': ['auth.User']}, |
|
208 |
'activation_sent': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
209 |
'affiliation': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}), |
|
210 |
'astakos_groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.AstakosGroup']", 'symmetrical': 'False', 'through': "orm['im.Membership']", 'blank': 'True'}), |
|
211 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
|
212 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
213 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
214 |
'date_signed_terms': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
215 |
'email_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
216 |
'has_credits': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
217 |
'has_signed_terms': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
218 |
'invitations': ('django.db.models.fields.IntegerField', [], {'default': '100'}), |
|
219 |
'is_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
220 |
'level': ('django.db.models.fields.IntegerField', [], {'default': '0'}), |
|
221 |
'owner': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'owner'", 'null': 'True', 'to': "orm['im.AstakosGroup']"}), |
|
222 |
'policy': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.AstakosUserQuota']", 'symmetrical': 'False'}), |
|
223 |
'provider': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}), |
|
224 |
'third_party_identifier': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
|
225 |
'updated': ('django.db.models.fields.DateTimeField', [], {}), |
|
226 |
'user_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True', 'primary_key': 'True'}) |
|
227 |
}, |
|
228 |
'im.astakosuserquota': { |
|
229 |
'Meta': {'object_name': 'AstakosUserQuota'}, |
|
230 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
231 |
'limit': ('django.db.models.fields.PositiveIntegerField', [], {}), |
|
232 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}), |
|
233 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
234 |
}, |
|
235 |
'im.emailchange': { |
|
236 |
'Meta': {'object_name': 'EmailChange'}, |
|
237 |
'activation_key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}), |
|
238 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
239 |
'new_email_address': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
|
240 |
'requested_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 2, 22, 23, 54, 139243)'}), |
|
241 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'emailchange_user'", 'unique': 'True', 'to': "orm['im.AstakosUser']"}) |
|
242 |
}, |
|
243 |
'im.groupkind': { |
|
244 |
'Meta': {'object_name': 'GroupKind'}, |
|
245 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
246 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}) |
|
247 |
}, |
|
248 |
'im.invitation': { |
|
249 |
'Meta': {'object_name': 'Invitation'}, |
|
250 |
'code': ('django.db.models.fields.BigIntegerField', [], {'db_index': 'True'}), |
|
251 |
'consumed': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
252 |
'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}), |
|
253 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
254 |
'inviter': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'invitations_sent'", 'null': 'True', 'to': "orm['im.AstakosUser']"}), |
|
255 |
'is_consumed': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
256 |
'realname': ('django.db.models.fields.CharField', [], {'max_length': '255'}), |
|
257 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}) |
|
258 |
}, |
|
259 |
'im.membership': { |
|
260 |
'Meta': {'unique_together': "(('person', 'group'),)", 'object_name': 'Membership'}, |
|
261 |
'date_joined': ('django.db.models.fields.DateField', [], {'null': 'True', 'db_index': 'True'}), |
|
262 |
'date_requested': ('django.db.models.fields.DateField', [], {'default': 'datetime.datetime(2012, 8, 2, 22, 23, 54, 135644)'}), |
|
263 |
'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosGroup']"}), |
|
264 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
265 |
'person': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
266 |
}, |
|
267 |
'im.resource': { |
|
268 |
'Meta': {'object_name': 'Resource'}, |
|
269 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
270 |
'meta': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.ResourceMetadata']", 'symmetrical': 'False'}), |
|
271 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
272 |
'service': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Service']"}) |
|
273 |
}, |
|
274 |
'im.resourcemetadata': { |
|
275 |
'Meta': {'object_name': 'ResourceMetadata'}, |
|
276 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
277 |
'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
278 |
'value': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
|
279 |
}, |
|
280 |
'im.service': { |
|
281 |
'Meta': {'object_name': 'Service'}, |
|
282 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
|
283 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
284 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
285 |
'icon': ('django.db.models.fields.FilePathField', [], {'max_length': '100', 'blank': 'True'}), |
|
286 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
287 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
288 |
'url': ('django.db.models.fields.FilePathField', [], {'max_length': '100'}) |
|
289 |
} |
|
290 |
} |
|
291 |
|
|
292 |
complete_apps = ['im'] |
/dev/null | ||
---|---|---|
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 unique constraint on 'AstakosGroupQuota', fields ['group', 'resource'] |
|
12 |
db.create_unique('im_astakosgroupquota', ['group_id', 'resource_id']) |
|
13 |
|
|
14 |
# Adding unique constraint on 'AstakosUserQuota', fields ['resource', 'user'] |
|
15 |
db.create_unique('im_astakosuserquota', ['resource_id', 'user_id']) |
|
16 |
|
|
17 |
|
|
18 |
def backwards(self, orm): |
|
19 |
|
|
20 |
# Removing unique constraint on 'AstakosUserQuota', fields ['resource', 'user'] |
|
21 |
db.delete_unique('im_astakosuserquota', ['resource_id', 'user_id']) |
|
22 |
|
|
23 |
# Removing unique constraint on 'AstakosGroupQuota', fields ['group', 'resource'] |
|
24 |
db.delete_unique('im_astakosgroupquota', ['group_id', 'resource_id']) |
|
25 |
|
|
26 |
|
|
27 |
models = { |
|
28 |
'auth.group': { |
|
29 |
'Meta': {'object_name': 'Group'}, |
|
30 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
31 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}), |
|
32 |
'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}) |
|
33 |
}, |
|
34 |
'auth.permission': { |
|
35 |
'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'}, |
|
36 |
'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
37 |
'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}), |
|
38 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
39 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}) |
|
40 |
}, |
|
41 |
'auth.user': { |
|
42 |
'Meta': {'object_name': 'User'}, |
|
43 |
'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
|
44 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}), |
|
45 |
'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
|
46 |
'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}), |
|
47 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
48 |
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), |
|
49 |
'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
50 |
'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
51 |
'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
|
52 |
'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
|
53 |
'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}), |
|
54 |
'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}), |
|
55 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'}) |
|
56 |
}, |
|
57 |
'contenttypes.contenttype': { |
|
58 |
'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"}, |
|
59 |
'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
60 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
61 |
'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
|
62 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}) |
|
63 |
}, |
|
64 |
'im.additionalmail': { |
|
65 |
'Meta': {'object_name': 'AdditionalMail'}, |
|
66 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
|
67 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
68 |
'owner': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
69 |
}, |
|
70 |
'im.approvalterms': { |
|
71 |
'Meta': {'object_name': 'ApprovalTerms'}, |
|
72 |
'date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 3, 1, 33, 55, 30509)', 'db_index': 'True'}), |
|
73 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
74 |
'location': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
|
75 |
}, |
|
76 |
'im.astakosgroup': { |
|
77 |
'Meta': {'object_name': 'AstakosGroup', '_ormbases': ['auth.Group']}, |
|
78 |
'approval_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
79 |
'creation_date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 3, 1, 33, 55, 24384)'}), |
|
80 |
'desc': ('django.db.models.fields.TextField', [], {'null': 'True'}), |
|
81 |
'estimated_participants': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}), |
|
82 |
'expiration_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
83 |
'group_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.Group']", 'unique': 'True', 'primary_key': 'True'}), |
|
84 |
'identifier': ('django.db.models.fields.URLField', [], {'default': "''", 'unique': 'True', 'max_length': '200', 'db_index': 'True'}), |
|
85 |
'issue_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
86 |
'kind': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.GroupKind']"}), |
|
87 |
'moderatation_enabled': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
88 |
'policy': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.AstakosGroupQuota']", 'blank': 'True'}) |
|
89 |
}, |
|
90 |
'im.astakosgroupquota': { |
|
91 |
'Meta': {'unique_together': "(('resource', 'group'),)", 'object_name': 'AstakosGroupQuota'}, |
|
92 |
'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosGroup']"}), |
|
93 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
94 |
'limit': ('django.db.models.fields.PositiveIntegerField', [], {}), |
|
95 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}) |
|
96 |
}, |
|
97 |
'im.astakosuser': { |
|
98 |
'Meta': {'unique_together': "(('provider', 'third_party_identifier'),)", 'object_name': 'AstakosUser', '_ormbases': ['auth.User']}, |
|
99 |
'activation_sent': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
100 |
'affiliation': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}), |
|
101 |
'astakos_groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.AstakosGroup']", 'symmetrical': 'False', 'through': "orm['im.Membership']", 'blank': 'True'}), |
|
102 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
|
103 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
104 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
105 |
'date_signed_terms': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
106 |
'email_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
107 |
'has_credits': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
108 |
'has_signed_terms': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
109 |
'invitations': ('django.db.models.fields.IntegerField', [], {'default': '100'}), |
|
110 |
'is_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
111 |
'level': ('django.db.models.fields.IntegerField', [], {'default': '0'}), |
|
112 |
'owner': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'owner'", 'null': 'True', 'to': "orm['im.AstakosGroup']"}), |
|
113 |
'policy': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.AstakosUserQuota']", 'symmetrical': 'False'}), |
|
114 |
'provider': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}), |
|
115 |
'third_party_identifier': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
|
116 |
'updated': ('django.db.models.fields.DateTimeField', [], {}), |
|
117 |
'user_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True', 'primary_key': 'True'}) |
|
118 |
}, |
|
119 |
'im.astakosuserquota': { |
|
120 |
'Meta': {'unique_together': "(('resource', 'user'),)", 'object_name': 'AstakosUserQuota'}, |
|
121 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
122 |
'limit': ('django.db.models.fields.PositiveIntegerField', [], {}), |
|
123 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}), |
|
124 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
125 |
}, |
|
126 |
'im.emailchange': { |
|
127 |
'Meta': {'object_name': 'EmailChange'}, |
|
128 |
'activation_key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}), |
|
129 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
130 |
'new_email_address': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
|
131 |
'requested_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 8, 3, 1, 33, 55, 32043)'}), |
|
132 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'emailchange_user'", 'unique': 'True', 'to': "orm['im.AstakosUser']"}) |
|
133 |
}, |
|
134 |
'im.groupkind': { |
|
135 |
'Meta': {'object_name': 'GroupKind'}, |
|
136 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
137 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}) |
|
138 |
}, |
|
139 |
'im.invitation': { |
|
140 |
'Meta': {'object_name': 'Invitation'}, |
|
141 |
'code': ('django.db.models.fields.BigIntegerField', [], {'db_index': 'True'}), |
|
142 |
'consumed': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
|
143 |
'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}), |
|
144 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
145 |
'inviter': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'invitations_sent'", 'null': 'True', 'to': "orm['im.AstakosUser']"}), |
|
146 |
'is_consumed': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
|
147 |
'realname': ('django.db.models.fields.CharField', [], {'max_length': '255'}), |
|
148 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}) |
|
149 |
}, |
|
150 |
'im.membership': { |
|
151 |
'Meta': {'unique_together': "(('person', 'group'),)", 'object_name': 'Membership'}, |
|
152 |
'date_joined': ('django.db.models.fields.DateField', [], {'null': 'True', 'db_index': 'True'}), |
|
153 |
'date_requested': ('django.db.models.fields.DateField', [], {'default': 'datetime.datetime(2012, 8, 3, 1, 33, 55, 28179)'}), |
|
154 |
'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosGroup']"}), |
|
155 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
156 |
'person': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
|
157 |
}, |
|
158 |
'im.resource': { |
|
159 |
'Meta': {'object_name': 'Resource'}, |
|
160 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
161 |
'meta': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.ResourceMetadata']", 'symmetrical': 'False'}), |
|
162 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
163 |
'service': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Service']"}) |
|
164 |
}, |
|
165 |
'im.resourcemetadata': { |
|
166 |
'Meta': {'object_name': 'ResourceMetadata'}, |
|
167 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
168 |
'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
169 |
'value': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
|
170 |
}, |
|
171 |
'im.service': { |
|
172 |
'Meta': {'object_name': 'Service'}, |
|
173 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
|
174 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
175 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
|
176 |
'icon': ('django.db.models.fields.FilePathField', [], {'max_length': '100', 'blank': 'True'}), |
|
177 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
|
178 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
|
179 |
'url': ('django.db.models.fields.FilePathField', [], {'max_length': '100'}) |
|
180 |
} |
|
181 |
} |
|
182 |
|
|
183 |
complete_apps = ['im'] |
b/snf-astakos-app/astakos/im/models.py | ||
---|---|---|
109 | 109 |
class AstakosGroup(Group): |
110 | 110 |
kind = models.ForeignKey(GroupKind) |
111 | 111 |
desc = models.TextField('Description', null=True) |
112 |
identifier = models.URLField('URI identifier', unique=True, default='', db_index=True) |
|
113 | 112 |
policy = models.ManyToManyField(Resource, null=True, blank=True, through='AstakosGroupQuota') |
114 | 113 |
creation_date = models.DateTimeField('Creation date', default=datetime.now()) |
115 | 114 |
issue_date = models.DateTimeField('Issue date', null=True) |
116 | 115 |
expiration_date = models.DateTimeField('Expiration date', null=True) |
117 | 116 |
moderatation_enabled = models.BooleanField('Moderated membership?', default=False) |
118 | 117 |
approval_date = models.DateTimeField('Activation date', null=True, blank=True) |
119 |
estimated_participants = models.PositiveIntegerField('Estimated number of participants', null=True)
|
|
118 |
estimated_participants = models.PositiveIntegerField('Estimated #participants', null=True)
|
|
120 | 119 |
|
121 | 120 |
@property |
122 | 121 |
def is_disabled(self): |
Also available in: Unified diff