root / snf-astakos-app / astakos / im / migrations / 0016_auth_providers_and_projects.py @ b052f360
History | View | Annotate | Download (25.4 kB)
1 |
# encoding: utf-8
|
---|---|
2 |
import datetime |
3 |
import uuid |
4 |
|
5 |
from south.db import db |
6 |
from south.v2 import DataMigration |
7 |
from django.db import models |
8 |
from django.core.validators import email_re |
9 |
|
10 |
from django.conf import settings |
11 |
|
12 |
class Migration(DataMigration): |
13 |
|
14 |
def forwards(self, orm): |
15 |
# valid activation_sent/email_verified
|
16 |
for user in orm.AstakosUser.objects.all(): |
17 |
if user.is_active:
|
18 |
if not user.activation_sent: |
19 |
user.activation_sent = datetime.datetime.now() |
20 |
user.email_verified = True
|
21 |
user.save() |
22 |
|
23 |
while not user.uuid: |
24 |
uuid_val = str(uuid.uuid4())
|
25 |
try:
|
26 |
orm.AstakosUser.objects.get(uuid=uuid_val) |
27 |
except orm.AstakosUser.DoesNotExist, e:
|
28 |
user.uuid = uuid_val |
29 |
user.save() |
30 |
|
31 |
# migrate to auth providers
|
32 |
for user in orm.AstakosUser.objects.all(): |
33 |
if user.provider and user.provider != 'local': |
34 |
orm.AstakosUserAuthProvider.objects.create(user=user, |
35 |
module=user.provider, |
36 |
identifier=user.third_party_identifier) |
37 |
else:
|
38 |
orm.AstakosUserAuthProvider.objects.create(user=user, |
39 |
module='local',
|
40 |
auth_backend='astakos')
|
41 |
|
42 |
user.save() |
43 |
|
44 |
# migrate duplicate emails
|
45 |
to_remove = getattr(settings,
|
46 |
'ASTAKOS_MIGRATION_0045_DELETE_DUPLICATE_USER_IDS',
|
47 |
[]) |
48 |
for pk in to_remove: |
49 |
try:
|
50 |
u = orm.AstakosUser.objects.get(pk=int(pk))
|
51 |
print "Removing user: %s (%d)" % (u.email, u.pk) |
52 |
except Exception: |
53 |
msg = "You requested user with id %s to be removed but such user doesn't exist in database" % str(pk) |
54 |
raise Exception(msg) |
55 |
|
56 |
if orm.AstakosUser.objects.filter(email__iexact=u.email).count() == 1: |
57 |
msg = ("You requested user with duplicate email %s and id (%d) to"
|
58 |
" be removed, but it seems that only one user exists with this"
|
59 |
" email in the database.") % (u.email , pk)
|
60 |
raise Exception(msg) |
61 |
else:
|
62 |
orm.AstakosUser.objects.filter(pk=int(pk)).delete()
|
63 |
|
64 |
for u in orm.AstakosUser.objects.all(): |
65 |
if orm.AstakosUser.objects.filter(email__iexact=u.email).count() > 1: |
66 |
existing = orm.AstakosUser.objects.filter( |
67 |
email__iexact=u.email) |
68 |
print "Duplicate email found in database" |
69 |
for e in existing: |
70 |
print "%d: %s (is_active: %s)" % (e.pk, e.email, e.is_active) |
71 |
keep = input("Select which user id you want to BE PRESERVED in the database: ") |
72 |
if keep:
|
73 |
for e in existing.exclude(pk=int(keep)): |
74 |
e.delete() |
75 |
else:
|
76 |
raise Exception("Email %s is not unique %r. Please resolve conflicts and run migrate again." % (u.email, |
77 |
existing)) |
78 |
u = orm.AstakosUser.objects.get(email__iexact=u.email) |
79 |
save = False
|
80 |
if not email_re.match(u.username): |
81 |
u.username = u.email.lower() |
82 |
save = True
|
83 |
if save:
|
84 |
u.save() |
85 |
|
86 |
|
87 |
def backwards(self, orm): |
88 |
# set third_party_identifier
|
89 |
for user in orm.AstakosUser.objects.all(): |
90 |
for auth_provider in user.auth_providers.all(): |
91 |
user.provider = auth_provider.module |
92 |
user.third_party_identifier = auth_provider.identifier |
93 |
|
94 |
user.save() |
95 |
|
96 |
# reset usernames
|
97 |
for u in orm.AstakosUser.objects.all(): |
98 |
u.uuid = None
|
99 |
u.auth_providers.all().delete() |
100 |
if email_re.match(u.username):
|
101 |
username = None
|
102 |
while not username: |
103 |
username_val = uuid.uuid4().hex[:30]
|
104 |
try:
|
105 |
orm.AstakosUser.objects.get(username = username_val) |
106 |
except orm.AstakosUser.DoesNotExist, e:
|
107 |
username = username_val |
108 |
u.username = username |
109 |
u.save() |
110 |
|
111 |
|
112 |
models = { |
113 |
'auth.group': {
|
114 |
'Meta': {'object_name': 'Group'}, |
115 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
116 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}), |
117 |
'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}) |
118 |
}, |
119 |
'auth.permission': {
|
120 |
'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'}, |
121 |
'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
122 |
'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}), |
123 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
124 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}) |
125 |
}, |
126 |
'auth.user': {
|
127 |
'Meta': {'object_name': 'User'}, |
128 |
'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
129 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}), |
130 |
'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
131 |
'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}), |
132 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
133 |
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), |
134 |
'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
135 |
'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
136 |
'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
137 |
'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}), |
138 |
'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}), |
139 |
'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}), |
140 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'}) |
141 |
}, |
142 |
'contenttypes.contenttype': {
|
143 |
'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"}, |
144 |
'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
145 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
146 |
'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}), |
147 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}) |
148 |
}, |
149 |
'im.additionalmail': {
|
150 |
'Meta': {'object_name': 'AdditionalMail'}, |
151 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
152 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
153 |
'owner': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
154 |
}, |
155 |
'im.approvalterms': {
|
156 |
'Meta': {'object_name': 'ApprovalTerms'}, |
157 |
'date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2013, 1, 11, 14, 22, 49, 523700)', 'db_index': 'True'}), |
158 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
159 |
'location': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
160 |
}, |
161 |
'im.astakosuser': {
|
162 |
'Meta': {'object_name': 'AstakosUser', '_ormbases': ['auth.User']}, |
163 |
'activation_sent': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
164 |
'affiliation': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
165 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
166 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
167 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
168 |
'date_signed_terms': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
169 |
'disturbed_quota': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}), |
170 |
'email_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
171 |
'has_credits': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
172 |
'has_signed_terms': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
173 |
'invitations': ('django.db.models.fields.IntegerField', [], {'default': '0'}), |
174 |
'is_verified': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
175 |
'level': ('django.db.models.fields.IntegerField', [], {'default': '4'}), |
176 |
'policy': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.AstakosUserQuota']", 'symmetrical': 'False'}), |
177 |
'provider': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
178 |
'third_party_identifier': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
179 |
'updated': ('django.db.models.fields.DateTimeField', [], {}), |
180 |
'user_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True', 'primary_key': 'True'}), |
181 |
'uuid': ('django.db.models.fields.CharField', [], {'max_length': '255', 'unique': 'True', 'null': 'True'}) |
182 |
}, |
183 |
'im.astakosuserauthprovider': {
|
184 |
'Meta': {'ordering': "('module', 'created')", 'unique_together': "(('identifier', 'module', 'user'),)", 'object_name': 'AstakosUserAuthProvider'}, |
185 |
'active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), |
186 |
'affiliation': ('django.db.models.fields.CharField', [], {'default': 'None', 'max_length': '255', 'null': 'True', 'blank': 'True'}), |
187 |
'auth_backend': ('django.db.models.fields.CharField', [], {'default': "'astakos'", 'max_length': '255'}), |
188 |
'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}), |
189 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
190 |
'identifier': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
191 |
'info_data': ('django.db.models.fields.TextField', [], {'default': "''", 'null': 'True', 'blank': 'True'}), |
192 |
'module': ('django.db.models.fields.CharField', [], {'default': "'local'", 'max_length': '255'}), |
193 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'auth_providers'", 'to': "orm['im.AstakosUser']"}) |
194 |
}, |
195 |
'im.astakosuserquota': {
|
196 |
'Meta': {'unique_together': "(('resource', 'user'),)", 'object_name': 'AstakosUserQuota'}, |
197 |
'capacity': ('django.db.models.fields.BigIntegerField', [], {'null': 'True'}), |
198 |
'export_limit': ('django.db.models.fields.BigIntegerField', [], {'null': 'True'}), |
199 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
200 |
'import_limit': ('django.db.models.fields.BigIntegerField', [], {'null': 'True'}), |
201 |
'quantity': ('django.db.models.fields.BigIntegerField', [], {'null': 'True'}), |
202 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}), |
203 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}) |
204 |
}, |
205 |
'im.chain': {
|
206 |
'Meta': {'object_name': 'Chain'}, |
207 |
'chain': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}) |
208 |
}, |
209 |
'im.emailchange': {
|
210 |
'Meta': {'object_name': 'EmailChange'}, |
211 |
'activation_key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}), |
212 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
213 |
'new_email_address': ('django.db.models.fields.EmailField', [], {'max_length': '75'}), |
214 |
'requested_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2013, 1, 11, 14, 22, 49, 524502)'}), |
215 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'emailchanges'", 'unique': 'True', 'to': "orm['im.AstakosUser']"}) |
216 |
}, |
217 |
'im.invitation': {
|
218 |
'Meta': {'object_name': 'Invitation'}, |
219 |
'code': ('django.db.models.fields.BigIntegerField', [], {'db_index': 'True'}), |
220 |
'consumed': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
221 |
'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}), |
222 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
223 |
'inviter': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'invitations_sent'", 'null': 'True', 'to': "orm['im.AstakosUser']"}), |
224 |
'is_consumed': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), |
225 |
'realname': ('django.db.models.fields.CharField', [], {'max_length': '255'}), |
226 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}) |
227 |
}, |
228 |
'im.pendingthirdpartyuser': {
|
229 |
'Meta': {'unique_together': "(('provider', 'third_party_identifier'),)", 'object_name': 'PendingThirdPartyUser'}, |
230 |
'affiliation': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
231 |
'created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'null': 'True', 'blank': 'True'}), |
232 |
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'null': 'True', 'blank': 'True'}), |
233 |
'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True', 'blank': 'True'}), |
234 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
235 |
'info': ('django.db.models.fields.TextField', [], {'default': "''", 'null': 'True', 'blank': 'True'}), |
236 |
'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True', 'blank': 'True'}), |
237 |
'provider': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}), |
238 |
'third_party_identifier': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
239 |
'token': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}), |
240 |
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'}) |
241 |
}, |
242 |
'im.project': {
|
243 |
'Meta': {'object_name': 'Project'}, |
244 |
'application': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'project'", 'unique': 'True', 'to': "orm['im.ProjectApplication']"}), |
245 |
'creation_date': ('django.db.models.fields.DateTimeField', [], {}), |
246 |
'deactivation_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
247 |
'deactivation_reason': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True'}), |
248 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
249 |
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'db_index': 'True'}), |
250 |
'is_modified': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}), |
251 |
'last_approval_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
252 |
'members': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.AstakosUser']", 'through': "orm['im.ProjectMembership']", 'symmetrical': 'False'}), |
253 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80', 'db_index': 'True'}), |
254 |
'state': ('django.db.models.fields.IntegerField', [], {'default': '1', 'db_index': 'True'}) |
255 |
}, |
256 |
'im.projectapplication': {
|
257 |
'Meta': {'unique_together': "(('chain', 'id'),)", 'object_name': 'ProjectApplication'}, |
258 |
'applicant': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'projects_applied'", 'to': "orm['im.AstakosUser']"}), |
259 |
'chain': ('django.db.models.fields.IntegerField', [], {}), |
260 |
'comments': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}), |
261 |
'description': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}), |
262 |
'end_date': ('django.db.models.fields.DateTimeField', [], {}), |
263 |
'homepage': ('django.db.models.fields.URLField', [], {'max_length': '255', 'null': 'True'}), |
264 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
265 |
'issue_date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}), |
266 |
'limit_on_members_number': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}), |
267 |
'member_join_policy': ('django.db.models.fields.IntegerField', [], {}), |
268 |
'member_leave_policy': ('django.db.models.fields.IntegerField', [], {}), |
269 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '80'}), |
270 |
'owner': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'projects_owned'", 'to': "orm['im.AstakosUser']"}), |
271 |
'precursor_application': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['im.ProjectApplication']", 'unique': 'True', 'null': 'True', 'blank': 'True'}), |
272 |
'resource_grants': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': "orm['im.Resource']", 'null': 'True', 'through': "orm['im.ProjectResourceGrant']", 'blank': 'True'}), |
273 |
'start_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), |
274 |
'state': ('django.db.models.fields.IntegerField', [], {'default': '0'}) |
275 |
}, |
276 |
'im.projectmembership': {
|
277 |
'Meta': {'unique_together': "(('person', 'project'),)", 'object_name': 'ProjectMembership'}, |
278 |
'acceptance_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'db_index': 'True'}), |
279 |
'application': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'memberships'", 'null': 'True', 'to': "orm['im.ProjectApplication']"}), |
280 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
281 |
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}), |
282 |
'is_pending': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}), |
283 |
'leave_request_date': ('django.db.models.fields.DateField', [], {'null': 'True'}), |
284 |
'pending_application': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'pending_memebrships'", 'null': 'True', 'to': "orm['im.ProjectApplication']"}), |
285 |
'pending_serial': ('django.db.models.fields.BigIntegerField', [], {'null': 'True', 'db_index': 'True'}), |
286 |
'person': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.AstakosUser']"}), |
287 |
'project': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Project']"}), |
288 |
'request_date': ('django.db.models.fields.DateField', [], {'default': 'datetime.datetime(2013, 1, 11, 14, 22, 49, 528323)'}), |
289 |
'state': ('django.db.models.fields.IntegerField', [], {'default': '0', 'db_index': 'True'}) |
290 |
}, |
291 |
'im.projectmembershiphistory': {
|
292 |
'Meta': {'object_name': 'ProjectMembershipHistory'}, |
293 |
'date': ('django.db.models.fields.DateField', [], {'default': 'datetime.datetime.now'}), |
294 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
295 |
'person': ('django.db.models.fields.BigIntegerField', [], {}), |
296 |
'project': ('django.db.models.fields.BigIntegerField', [], {}), |
297 |
'reason': ('django.db.models.fields.IntegerField', [], {}), |
298 |
'serial': ('django.db.models.fields.BigIntegerField', [], {}) |
299 |
}, |
300 |
'im.projectresourcegrant': {
|
301 |
'Meta': {'unique_together': "(('resource', 'project_application'),)", 'object_name': 'ProjectResourceGrant'}, |
302 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
303 |
'member_capacity': ('snf_django.lib.db.fields.IntDecimalField', [], {'default': '100000000000000000000000000000000L', 'max_digits': '38', 'decimal_places': '0'}), |
304 |
'member_export_limit': ('snf_django.lib.db.fields.IntDecimalField', [], {'default': '100000000000000000000000000000000L', 'max_digits': '38', 'decimal_places': '0'}), |
305 |
'member_import_limit': ('snf_django.lib.db.fields.IntDecimalField', [], {'default': '100000000000000000000000000000000L', 'max_digits': '38', 'decimal_places': '0'}), |
306 |
'project_application': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.ProjectApplication']", 'null': 'True'}), |
307 |
'project_capacity': ('snf_django.lib.db.fields.IntDecimalField', [], {'default': '100000000000000000000000000000000L', 'max_digits': '38', 'decimal_places': '0'}), |
308 |
'project_export_limit': ('snf_django.lib.db.fields.IntDecimalField', [], {'default': '100000000000000000000000000000000L', 'max_digits': '38', 'decimal_places': '0'}), |
309 |
'project_import_limit': ('snf_django.lib.db.fields.IntDecimalField', [], {'default': '100000000000000000000000000000000L', 'max_digits': '38', 'decimal_places': '0'}), |
310 |
'resource': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Resource']"}) |
311 |
}, |
312 |
'im.resource': {
|
313 |
'Meta': {'unique_together': "(('name', 'service'),)", 'object_name': 'Resource'}, |
314 |
'desc': ('django.db.models.fields.TextField', [], {'null': 'True'}), |
315 |
'group': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True'}), |
316 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
317 |
'meta': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['im.ResourceMetadata']", 'symmetrical': 'False'}), |
318 |
'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}), |
319 |
'service': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['im.Service']"}), |
320 |
'unit': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True'}) |
321 |
}, |
322 |
'im.resourcemetadata': {
|
323 |
'Meta': {'object_name': 'ResourceMetadata'}, |
324 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
325 |
'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
326 |
'value': ('django.db.models.fields.CharField', [], {'max_length': '255'}) |
327 |
}, |
328 |
'im.serial': {
|
329 |
'Meta': {'object_name': 'Serial'}, |
330 |
'serial': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}) |
331 |
}, |
332 |
'im.service': {
|
333 |
'Meta': {'ordering': "('order',)", 'object_name': 'Service'}, |
334 |
'auth_token': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True', 'blank': 'True'}), |
335 |
'auth_token_created': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
336 |
'auth_token_expires': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}), |
337 |
'icon': ('django.db.models.fields.FilePathField', [], {'max_length': '100', 'blank': 'True'}), |
338 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
339 |
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'}), |
340 |
'order': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}), |
341 |
'url': ('django.db.models.fields.FilePathField', [], {'max_length': '100'}) |
342 |
}, |
343 |
'im.sessioncatalog': {
|
344 |
'Meta': {'object_name': 'SessionCatalog'}, |
345 |
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), |
346 |
'session_key': ('django.db.models.fields.CharField', [], {'max_length': '40'}), |
347 |
'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'sessions'", 'null': 'True', 'to': "orm['im.AstakosUser']"}) |
348 |
} |
349 |
} |
350 |
|
351 |
complete_apps = ['im']
|