mirror of https://github.com/zulip/zulip.git
[manual] Excise South migrations prior to the User merge.
South doesn't properly deal with removing the Django User model, so this commit redoes our South history to instead start after that migration has already been applied. This allows us to get rid of some annoying hacks. Note that developers and staging will need to run ./manage.py migrate --delete-ghost-migrations zephyr in order to clear out the old versions of the migrations. (imported from commit 7f45ea601b809dde33720f76e7dfb0ab348b0e65)
This commit is contained in:
parent
56949b4788
commit
fe987fb1c3
|
@ -1,9 +0,0 @@
|
|||
from settings import *
|
||||
|
||||
# South doesn't support an application migrating from having not
|
||||
# having a non-default AUTH_USER_MODEL to having one because in the
|
||||
# latter case it doesn't emit an auth_user table, but our migrations
|
||||
# expect it to exist at the beginning and then go away (and thus will
|
||||
# fail). So we change this back to the default for running our
|
||||
# initial syncdb so that we still emit an auth_user table then.
|
||||
AUTH_USER_MODEL = "auth.User"
|
|
@ -31,7 +31,6 @@ node_modules
|
|||
|
||||
exclude_files = """
|
||||
humbug/test_settings.py
|
||||
humbug/setup_hack_settings.py
|
||||
tools/jslint/jslint.js
|
||||
""".split()
|
||||
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
|
||||
echo "DROP SCHEMA humbug CASCADE; CREATE SCHEMA humbug;" | python manage.py dbshell
|
||||
|
||||
python manage.py syncdb --noinput --settings=humbug.setup_hack_settings
|
||||
python manage.py syncdb --noinput
|
||||
python manage.py migrate
|
||||
python manage.py createcachetable third_party_api_results
|
||||
python manage.py populate_db --replay-old-messages -n0
|
||||
|
|
|
@ -0,0 +1,351 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
import datetime
|
||||
from south.db import db
|
||||
from south.v2 import SchemaMigration
|
||||
from django.db import models
|
||||
|
||||
|
||||
class Migration(SchemaMigration):
|
||||
|
||||
def forwards(self, orm):
|
||||
# Adding model 'Realm'
|
||||
db.create_table('zephyr_realm', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('domain', self.gf('django.db.models.fields.CharField')(unique=True, max_length=40, db_index=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Realm'])
|
||||
|
||||
# Adding model 'UserProfile'
|
||||
db.create_table('zephyr_userprofile', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user', self.gf('django.db.models.fields.related.OneToOneField')(to=orm['auth.User'], unique=True)),
|
||||
('full_name', self.gf('django.db.models.fields.CharField')(max_length=100)),
|
||||
('short_name', self.gf('django.db.models.fields.CharField')(max_length=100)),
|
||||
('pointer', self.gf('django.db.models.fields.IntegerField')()),
|
||||
('last_pointer_updater', self.gf('django.db.models.fields.CharField')(max_length=64)),
|
||||
('realm', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Realm'])),
|
||||
('api_key', self.gf('django.db.models.fields.CharField')(max_length=32)),
|
||||
('enable_desktop_notifications', self.gf('django.db.models.fields.BooleanField')(default=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['UserProfile'])
|
||||
|
||||
# Adding model 'PreregistrationUser'
|
||||
db.create_table('zephyr_preregistrationuser', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('email', self.gf('django.db.models.fields.EmailField')(unique=True, max_length=75)),
|
||||
('status', self.gf('django.db.models.fields.IntegerField')(default=0)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['PreregistrationUser'])
|
||||
|
||||
# Adding model 'MitUser'
|
||||
db.create_table('zephyr_mituser', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('email', self.gf('django.db.models.fields.EmailField')(unique=True, max_length=75)),
|
||||
('status', self.gf('django.db.models.fields.IntegerField')(default=0)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['MitUser'])
|
||||
|
||||
# Adding model 'Stream'
|
||||
db.create_table('zephyr_stream', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('name', self.gf('django.db.models.fields.CharField')(max_length=30, db_index=True)),
|
||||
('realm', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Realm'])),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Stream'])
|
||||
|
||||
# Adding unique constraint on 'Stream', fields ['name', 'realm']
|
||||
db.create_unique('zephyr_stream', ['name', 'realm_id'])
|
||||
|
||||
# Adding model 'Recipient'
|
||||
db.create_table('zephyr_recipient', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('type_id', self.gf('django.db.models.fields.IntegerField')(db_index=True)),
|
||||
('type', self.gf('django.db.models.fields.PositiveSmallIntegerField')(db_index=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Recipient'])
|
||||
|
||||
# Adding unique constraint on 'Recipient', fields ['type', 'type_id']
|
||||
db.create_unique('zephyr_recipient', ['type', 'type_id'])
|
||||
|
||||
# Adding model 'Client'
|
||||
db.create_table('zephyr_client', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('name', self.gf('django.db.models.fields.CharField')(unique=True, max_length=30, db_index=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Client'])
|
||||
|
||||
# Adding model 'Message'
|
||||
db.create_table('zephyr_message', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('sender', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('recipient', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Recipient'])),
|
||||
('subject', self.gf('django.db.models.fields.CharField')(max_length=60, db_index=True)),
|
||||
('content', self.gf('django.db.models.fields.TextField')()),
|
||||
('pub_date', self.gf('django.db.models.fields.DateTimeField')(db_index=True)),
|
||||
('sending_client', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Client'])),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Message'])
|
||||
|
||||
# Adding model 'UserMessage'
|
||||
db.create_table('zephyr_usermessage', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user_profile', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('message', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Message'])),
|
||||
('archived', self.gf('django.db.models.fields.BooleanField')(default=False)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['UserMessage'])
|
||||
|
||||
# Adding unique constraint on 'UserMessage', fields ['user_profile', 'message']
|
||||
db.create_unique('zephyr_usermessage', ['user_profile_id', 'message_id'])
|
||||
|
||||
# Adding model 'Subscription'
|
||||
db.create_table('zephyr_subscription', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user_profile', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('recipient', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Recipient'])),
|
||||
('active', self.gf('django.db.models.fields.BooleanField')(default=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Subscription'])
|
||||
|
||||
# Adding unique constraint on 'Subscription', fields ['user_profile', 'recipient']
|
||||
db.create_unique('zephyr_subscription', ['user_profile_id', 'recipient_id'])
|
||||
|
||||
# Adding model 'Huddle'
|
||||
db.create_table('zephyr_huddle', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('huddle_hash', self.gf('django.db.models.fields.CharField')(unique=True, max_length=40, db_index=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Huddle'])
|
||||
|
||||
# Adding model 'UserActivity'
|
||||
db.create_table('zephyr_useractivity', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user_profile', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('client', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Client'])),
|
||||
('query', self.gf('django.db.models.fields.CharField')(max_length=50, db_index=True)),
|
||||
('count', self.gf('django.db.models.fields.IntegerField')()),
|
||||
('last_visit', self.gf('django.db.models.fields.DateTimeField')()),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['UserActivity'])
|
||||
|
||||
# Adding unique constraint on 'UserActivity', fields ['user_profile', 'client', 'query']
|
||||
db.create_unique('zephyr_useractivity', ['user_profile_id', 'client_id', 'query'])
|
||||
|
||||
# Adding model 'DefaultStream'
|
||||
db.create_table('zephyr_defaultstream', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('realm', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Realm'])),
|
||||
('stream', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Stream'])),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['DefaultStream'])
|
||||
|
||||
# Adding unique constraint on 'DefaultStream', fields ['realm', 'stream']
|
||||
db.create_unique('zephyr_defaultstream', ['realm_id', 'stream_id'])
|
||||
|
||||
# Adding model 'StreamColor'
|
||||
db.create_table('zephyr_streamcolor', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('subscription', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Subscription'])),
|
||||
('color', self.gf('django.db.models.fields.CharField')(max_length=10)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['StreamColor'])
|
||||
|
||||
|
||||
def backwards(self, orm):
|
||||
# Removing unique constraint on 'DefaultStream', fields ['realm', 'stream']
|
||||
db.delete_unique('zephyr_defaultstream', ['realm_id', 'stream_id'])
|
||||
|
||||
# Removing unique constraint on 'UserActivity', fields ['user_profile', 'client', 'query']
|
||||
db.delete_unique('zephyr_useractivity', ['user_profile_id', 'client_id', 'query'])
|
||||
|
||||
# Removing unique constraint on 'Subscription', fields ['user_profile', 'recipient']
|
||||
db.delete_unique('zephyr_subscription', ['user_profile_id', 'recipient_id'])
|
||||
|
||||
# Removing unique constraint on 'UserMessage', fields ['user_profile', 'message']
|
||||
db.delete_unique('zephyr_usermessage', ['user_profile_id', 'message_id'])
|
||||
|
||||
# Removing unique constraint on 'Recipient', fields ['type', 'type_id']
|
||||
db.delete_unique('zephyr_recipient', ['type', 'type_id'])
|
||||
|
||||
# Removing unique constraint on 'Stream', fields ['name', 'realm']
|
||||
db.delete_unique('zephyr_stream', ['name', 'realm_id'])
|
||||
|
||||
# Deleting model 'Realm'
|
||||
db.delete_table('zephyr_realm')
|
||||
|
||||
# Deleting model 'UserProfile'
|
||||
db.delete_table('zephyr_userprofile')
|
||||
|
||||
# Deleting model 'PreregistrationUser'
|
||||
db.delete_table('zephyr_preregistrationuser')
|
||||
|
||||
# Deleting model 'MitUser'
|
||||
db.delete_table('zephyr_mituser')
|
||||
|
||||
# Deleting model 'Stream'
|
||||
db.delete_table('zephyr_stream')
|
||||
|
||||
# Deleting model 'Recipient'
|
||||
db.delete_table('zephyr_recipient')
|
||||
|
||||
# Deleting model 'Client'
|
||||
db.delete_table('zephyr_client')
|
||||
|
||||
# Deleting model 'Message'
|
||||
db.delete_table('zephyr_message')
|
||||
|
||||
# Deleting model 'UserMessage'
|
||||
db.delete_table('zephyr_usermessage')
|
||||
|
||||
# Deleting model 'Subscription'
|
||||
db.delete_table('zephyr_subscription')
|
||||
|
||||
# Deleting model 'Huddle'
|
||||
db.delete_table('zephyr_huddle')
|
||||
|
||||
# Deleting model 'UserActivity'
|
||||
db.delete_table('zephyr_useractivity')
|
||||
|
||||
# Deleting model 'DefaultStream'
|
||||
db.delete_table('zephyr_defaultstream')
|
||||
|
||||
# Deleting model 'StreamColor'
|
||||
db.delete_table('zephyr_streamcolor')
|
||||
|
||||
|
||||
models = {
|
||||
'auth.group': {
|
||||
'Meta': {'object_name': 'Group'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
|
||||
'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
|
||||
},
|
||||
'auth.permission': {
|
||||
'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
|
||||
'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
|
||||
},
|
||||
'auth.user': {
|
||||
'Meta': {'object_name': 'User'},
|
||||
'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
|
||||
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
|
||||
'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
|
||||
'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
||||
'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
||||
'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
||||
'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
|
||||
'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
|
||||
'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
||||
'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
|
||||
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
|
||||
},
|
||||
'contenttypes.contenttype': {
|
||||
'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
|
||||
'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
|
||||
},
|
||||
'zephyr.client': {
|
||||
'Meta': {'object_name': 'Client'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30', 'db_index': 'True'})
|
||||
},
|
||||
'zephyr.defaultstream': {
|
||||
'Meta': {'unique_together': "(('realm', 'stream'),)", 'object_name': 'DefaultStream'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Realm']"}),
|
||||
'stream': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Stream']"})
|
||||
},
|
||||
'zephyr.huddle': {
|
||||
'Meta': {'object_name': 'Huddle'},
|
||||
'huddle_hash': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'})
|
||||
},
|
||||
'zephyr.message': {
|
||||
'Meta': {'object_name': 'Message'},
|
||||
'content': ('django.db.models.fields.TextField', [], {}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'pub_date': ('django.db.models.fields.DateTimeField', [], {'db_index': 'True'}),
|
||||
'recipient': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Recipient']"}),
|
||||
'sender': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"}),
|
||||
'sending_client': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Client']"}),
|
||||
'subject': ('django.db.models.fields.CharField', [], {'max_length': '60', 'db_index': 'True'})
|
||||
},
|
||||
'zephyr.mituser': {
|
||||
'Meta': {'object_name': 'MitUser'},
|
||||
'email': ('django.db.models.fields.EmailField', [], {'unique': 'True', 'max_length': '75'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'status': ('django.db.models.fields.IntegerField', [], {'default': '0'})
|
||||
},
|
||||
'zephyr.preregistrationuser': {
|
||||
'Meta': {'object_name': 'PreregistrationUser'},
|
||||
'email': ('django.db.models.fields.EmailField', [], {'unique': 'True', 'max_length': '75'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'status': ('django.db.models.fields.IntegerField', [], {'default': '0'})
|
||||
},
|
||||
'zephyr.realm': {
|
||||
'Meta': {'object_name': 'Realm'},
|
||||
'domain': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'})
|
||||
},
|
||||
'zephyr.recipient': {
|
||||
'Meta': {'unique_together': "(('type', 'type_id'),)", 'object_name': 'Recipient'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'type': ('django.db.models.fields.PositiveSmallIntegerField', [], {'db_index': 'True'}),
|
||||
'type_id': ('django.db.models.fields.IntegerField', [], {'db_index': 'True'})
|
||||
},
|
||||
'zephyr.stream': {
|
||||
'Meta': {'unique_together': "(('name', 'realm'),)", 'object_name': 'Stream'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'db_index': 'True'}),
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Realm']"})
|
||||
},
|
||||
'zephyr.streamcolor': {
|
||||
'Meta': {'object_name': 'StreamColor'},
|
||||
'color': ('django.db.models.fields.CharField', [], {'max_length': '10'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'subscription': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Subscription']"})
|
||||
},
|
||||
'zephyr.subscription': {
|
||||
'Meta': {'unique_together': "(('user_profile', 'recipient'),)", 'object_name': 'Subscription'},
|
||||
'active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'recipient': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Recipient']"}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"})
|
||||
},
|
||||
'zephyr.useractivity': {
|
||||
'Meta': {'unique_together': "(('user_profile', 'client', 'query'),)", 'object_name': 'UserActivity'},
|
||||
'client': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Client']"}),
|
||||
'count': ('django.db.models.fields.IntegerField', [], {}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'last_visit': ('django.db.models.fields.DateTimeField', [], {}),
|
||||
'query': ('django.db.models.fields.CharField', [], {'max_length': '50', 'db_index': 'True'}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"})
|
||||
},
|
||||
'zephyr.usermessage': {
|
||||
'Meta': {'unique_together': "(('user_profile', 'message'),)", 'object_name': 'UserMessage'},
|
||||
'archived': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'message': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Message']"}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"})
|
||||
},
|
||||
'zephyr.userprofile': {
|
||||
'Meta': {'object_name': 'UserProfile'},
|
||||
'api_key': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
|
||||
'enable_desktop_notifications': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
||||
'full_name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'last_pointer_updater': ('django.db.models.fields.CharField', [], {'max_length': '64'}),
|
||||
'pointer': ('django.db.models.fields.IntegerField', [], {}),
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Realm']"}),
|
||||
'short_name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'user': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True'})
|
||||
}
|
||||
}
|
||||
|
||||
complete_apps = ['zephyr']
|
|
@ -3,22 +3,28 @@ import datetime
|
|||
from south.db import db
|
||||
from south.v2 import SchemaMigration
|
||||
from django.db import models
|
||||
|
||||
from django.conf import settings
|
||||
|
||||
class Migration(SchemaMigration):
|
||||
|
||||
def forwards(self, orm):
|
||||
# Adding model 'Realm'
|
||||
db.create_table('zephyr_realm', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_realm', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('domain', self.gf('django.db.models.fields.CharField')(unique=True, max_length=40, db_index=True)),
|
||||
('restricted_to_domain', self.gf('django.db.models.fields.BooleanField')(default=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Realm'])
|
||||
db.send_create_signal(u'zephyr', ['Realm'])
|
||||
|
||||
# Adding model 'UserProfile'
|
||||
db.create_table('zephyr_userprofile', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user', self.gf('django.db.models.fields.related.OneToOneField')(to=orm['auth.User'], unique=True)),
|
||||
db.create_table(u'zephyr_userprofile', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('password', self.gf('django.db.models.fields.CharField')(max_length=128)),
|
||||
('last_login', self.gf('django.db.models.fields.DateTimeField')(default=datetime.datetime.now)),
|
||||
('email', self.gf('django.db.models.fields.EmailField')(max_length=75, blank=True)),
|
||||
('is_staff', self.gf('django.db.models.fields.BooleanField')(default=False)),
|
||||
('is_active', self.gf('django.db.models.fields.BooleanField')(default=True)),
|
||||
('date_joined', self.gf('django.db.models.fields.DateTimeField')(default=datetime.datetime.now)),
|
||||
('full_name', self.gf('django.db.models.fields.CharField')(max_length=100)),
|
||||
('short_name', self.gf('django.db.models.fields.CharField')(max_length=100)),
|
||||
('pointer', self.gf('django.db.models.fields.IntegerField')()),
|
||||
|
@ -26,326 +32,366 @@ class Migration(SchemaMigration):
|
|||
('realm', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Realm'])),
|
||||
('api_key', self.gf('django.db.models.fields.CharField')(max_length=32)),
|
||||
('enable_desktop_notifications', self.gf('django.db.models.fields.BooleanField')(default=True)),
|
||||
('enter_sends', self.gf('django.db.models.fields.NullBooleanField')(default=False, null=True, blank=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['UserProfile'])
|
||||
db.send_create_signal(u'zephyr', ['UserProfile'])
|
||||
|
||||
# Adding model 'PreregistrationUser'
|
||||
db.create_table('zephyr_preregistrationuser', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('email', self.gf('django.db.models.fields.EmailField')(unique=True, max_length=75)),
|
||||
db.create_table(u'zephyr_preregistrationuser', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('email', self.gf('django.db.models.fields.EmailField')(max_length=75)),
|
||||
('referred_by', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'], null=True)),
|
||||
('invited_at', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, blank=True)),
|
||||
('status', self.gf('django.db.models.fields.IntegerField')(default=0)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['PreregistrationUser'])
|
||||
db.send_create_signal(u'zephyr', ['PreregistrationUser'])
|
||||
|
||||
# Adding M2M table for field streams on 'PreregistrationUser'
|
||||
db.create_table(u'zephyr_preregistrationuser_streams', (
|
||||
('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
|
||||
('preregistrationuser', models.ForeignKey(orm[u'zephyr.preregistrationuser'], null=False)),
|
||||
('stream', models.ForeignKey(orm[u'zephyr.stream'], null=False))
|
||||
))
|
||||
db.create_unique(u'zephyr_preregistrationuser_streams', ['preregistrationuser_id', 'stream_id'])
|
||||
|
||||
# Adding model 'MitUser'
|
||||
db.create_table('zephyr_mituser', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_mituser', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('email', self.gf('django.db.models.fields.EmailField')(unique=True, max_length=75)),
|
||||
('status', self.gf('django.db.models.fields.IntegerField')(default=0)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['MitUser'])
|
||||
db.send_create_signal(u'zephyr', ['MitUser'])
|
||||
|
||||
# Adding model 'Stream'
|
||||
db.create_table('zephyr_stream', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_stream', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('name', self.gf('django.db.models.fields.CharField')(max_length=30, db_index=True)),
|
||||
('realm', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Realm'])),
|
||||
('invite_only', self.gf('django.db.models.fields.NullBooleanField')(default=False, null=True, blank=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Stream'])
|
||||
db.send_create_signal(u'zephyr', ['Stream'])
|
||||
|
||||
# Adding unique constraint on 'Stream', fields ['name', 'realm']
|
||||
db.create_unique('zephyr_stream', ['name', 'realm_id'])
|
||||
db.create_unique(u'zephyr_stream', ['name', 'realm_id'])
|
||||
|
||||
# Adding model 'Recipient'
|
||||
db.create_table('zephyr_recipient', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_recipient', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('type_id', self.gf('django.db.models.fields.IntegerField')(db_index=True)),
|
||||
('type', self.gf('django.db.models.fields.PositiveSmallIntegerField')(db_index=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Recipient'])
|
||||
db.send_create_signal(u'zephyr', ['Recipient'])
|
||||
|
||||
# Adding unique constraint on 'Recipient', fields ['type', 'type_id']
|
||||
db.create_unique('zephyr_recipient', ['type', 'type_id'])
|
||||
db.create_unique(u'zephyr_recipient', ['type', 'type_id'])
|
||||
|
||||
# Adding model 'Client'
|
||||
db.create_table('zephyr_client', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_client', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('name', self.gf('django.db.models.fields.CharField')(unique=True, max_length=30, db_index=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Client'])
|
||||
db.send_create_signal(u'zephyr', ['Client'])
|
||||
|
||||
# Adding model 'Message'
|
||||
db.create_table('zephyr_message', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_message', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('sender', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('recipient', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Recipient'])),
|
||||
('subject', self.gf('django.db.models.fields.CharField')(max_length=60, db_index=True)),
|
||||
('content', self.gf('django.db.models.fields.TextField')()),
|
||||
('rendered_content', self.gf('django.db.models.fields.TextField')(null=True)),
|
||||
('rendered_content_version', self.gf('django.db.models.fields.IntegerField')(null=True)),
|
||||
('pub_date', self.gf('django.db.models.fields.DateTimeField')(db_index=True)),
|
||||
('sending_client', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Client'])),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Message'])
|
||||
db.send_create_signal(u'zephyr', ['Message'])
|
||||
|
||||
# Adding model 'UserMessage'
|
||||
db.create_table('zephyr_usermessage', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_usermessage', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user_profile', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('message', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Message'])),
|
||||
('archived', self.gf('django.db.models.fields.BooleanField')(default=False)),
|
||||
('flags', self.gf('django.db.models.fields.BigIntegerField')(default=0)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['UserMessage'])
|
||||
db.send_create_signal(u'zephyr', ['UserMessage'])
|
||||
|
||||
# Adding unique constraint on 'UserMessage', fields ['user_profile', 'message']
|
||||
db.create_unique('zephyr_usermessage', ['user_profile_id', 'message_id'])
|
||||
db.create_unique(u'zephyr_usermessage', ['user_profile_id', 'message_id'])
|
||||
|
||||
# Adding model 'Subscription'
|
||||
db.create_table('zephyr_subscription', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_subscription', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user_profile', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('recipient', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Recipient'])),
|
||||
('active', self.gf('django.db.models.fields.BooleanField')(default=True)),
|
||||
('in_home_view', self.gf('django.db.models.fields.NullBooleanField')(default=True, null=True, blank=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Subscription'])
|
||||
db.send_create_signal(u'zephyr', ['Subscription'])
|
||||
|
||||
# Adding unique constraint on 'Subscription', fields ['user_profile', 'recipient']
|
||||
db.create_unique('zephyr_subscription', ['user_profile_id', 'recipient_id'])
|
||||
db.create_unique(u'zephyr_subscription', ['user_profile_id', 'recipient_id'])
|
||||
|
||||
# Adding model 'Huddle'
|
||||
db.create_table('zephyr_huddle', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_huddle', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('huddle_hash', self.gf('django.db.models.fields.CharField')(unique=True, max_length=40, db_index=True)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['Huddle'])
|
||||
db.send_create_signal(u'zephyr', ['Huddle'])
|
||||
|
||||
# Adding model 'UserActivity'
|
||||
db.create_table('zephyr_useractivity', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_useractivity', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user_profile', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('client', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Client'])),
|
||||
('query', self.gf('django.db.models.fields.CharField')(max_length=50, db_index=True)),
|
||||
('count', self.gf('django.db.models.fields.IntegerField')()),
|
||||
('last_visit', self.gf('django.db.models.fields.DateTimeField')()),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['UserActivity'])
|
||||
db.send_create_signal(u'zephyr', ['UserActivity'])
|
||||
|
||||
# Adding unique constraint on 'UserActivity', fields ['user_profile', 'client', 'query']
|
||||
db.create_unique('zephyr_useractivity', ['user_profile_id', 'client_id', 'query'])
|
||||
db.create_unique(u'zephyr_useractivity', ['user_profile_id', 'client_id', 'query'])
|
||||
|
||||
# Adding model 'UserPresence'
|
||||
db.create_table(u'zephyr_userpresence', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('user_profile', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.UserProfile'])),
|
||||
('client', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Client'])),
|
||||
('timestamp', self.gf('django.db.models.fields.DateTimeField')()),
|
||||
('status', self.gf('django.db.models.fields.PositiveSmallIntegerField')(default=1)),
|
||||
))
|
||||
db.send_create_signal(u'zephyr', ['UserPresence'])
|
||||
|
||||
# Adding unique constraint on 'UserPresence', fields ['user_profile', 'client']
|
||||
db.create_unique(u'zephyr_userpresence', ['user_profile_id', 'client_id'])
|
||||
|
||||
# Adding model 'DefaultStream'
|
||||
db.create_table('zephyr_defaultstream', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_defaultstream', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('realm', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Realm'])),
|
||||
('stream', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Stream'])),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['DefaultStream'])
|
||||
db.send_create_signal(u'zephyr', ['DefaultStream'])
|
||||
|
||||
# Adding unique constraint on 'DefaultStream', fields ['realm', 'stream']
|
||||
db.create_unique('zephyr_defaultstream', ['realm_id', 'stream_id'])
|
||||
db.create_unique(u'zephyr_defaultstream', ['realm_id', 'stream_id'])
|
||||
|
||||
# Adding model 'StreamColor'
|
||||
db.create_table('zephyr_streamcolor', (
|
||||
('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
db.create_table(u'zephyr_streamcolor', (
|
||||
(u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
||||
('subscription', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['zephyr.Subscription'])),
|
||||
('color', self.gf('django.db.models.fields.CharField')(max_length=10)),
|
||||
))
|
||||
db.send_create_signal('zephyr', ['StreamColor'])
|
||||
db.send_create_signal(u'zephyr', ['StreamColor'])
|
||||
|
||||
if "postgres" not in settings.DATABASES["default"]["ENGINE"]:
|
||||
return
|
||||
# we do not populate search_tsvector, as the data which you'd normally populate it is empty (which would be a NO-OP).
|
||||
# Also, we populate it in a later migration.
|
||||
db.execute("ALTER TABLE zephyr_message ADD COLUMN search_tsvector tsvector")
|
||||
if len(db.execute("""SELECT relname FROM pg_class
|
||||
WHERE relname = 'zephyr_message_search_tsvector'""")) != 0:
|
||||
print "Not creating index because it already exists"
|
||||
else:
|
||||
db.execute("""CREATE INDEX zephyr_message_search_tsvector ON zephyr_message
|
||||
USING gin(search_tsvector)""")
|
||||
db.execute("""CREATE TRIGGER zephyr_message_update_search_tsvector
|
||||
BEFORE INSERT OR UPDATE ON zephyr_message FOR EACH ROW
|
||||
EXECUTE PROCEDURE tsvector_update_trigger(search_tsvector,
|
||||
'pg_catalog.english', subject, content)""");
|
||||
|
||||
def backwards(self, orm):
|
||||
# Removing unique constraint on 'DefaultStream', fields ['realm', 'stream']
|
||||
db.delete_unique('zephyr_defaultstream', ['realm_id', 'stream_id'])
|
||||
db.delete_unique(u'zephyr_defaultstream', ['realm_id', 'stream_id'])
|
||||
|
||||
# Removing unique constraint on 'UserPresence', fields ['user_profile', 'client']
|
||||
db.delete_unique(u'zephyr_userpresence', ['user_profile_id', 'client_id'])
|
||||
|
||||
# Removing unique constraint on 'UserActivity', fields ['user_profile', 'client', 'query']
|
||||
db.delete_unique('zephyr_useractivity', ['user_profile_id', 'client_id', 'query'])
|
||||
db.delete_unique(u'zephyr_useractivity', ['user_profile_id', 'client_id', 'query'])
|
||||
|
||||
# Removing unique constraint on 'Subscription', fields ['user_profile', 'recipient']
|
||||
db.delete_unique('zephyr_subscription', ['user_profile_id', 'recipient_id'])
|
||||
db.delete_unique(u'zephyr_subscription', ['user_profile_id', 'recipient_id'])
|
||||
|
||||
# Removing unique constraint on 'UserMessage', fields ['user_profile', 'message']
|
||||
db.delete_unique('zephyr_usermessage', ['user_profile_id', 'message_id'])
|
||||
db.delete_unique(u'zephyr_usermessage', ['user_profile_id', 'message_id'])
|
||||
|
||||
# Removing unique constraint on 'Recipient', fields ['type', 'type_id']
|
||||
db.delete_unique('zephyr_recipient', ['type', 'type_id'])
|
||||
db.delete_unique(u'zephyr_recipient', ['type', 'type_id'])
|
||||
|
||||
# Removing unique constraint on 'Stream', fields ['name', 'realm']
|
||||
db.delete_unique('zephyr_stream', ['name', 'realm_id'])
|
||||
db.delete_unique(u'zephyr_stream', ['name', 'realm_id'])
|
||||
|
||||
# Deleting model 'Realm'
|
||||
db.delete_table('zephyr_realm')
|
||||
db.delete_table(u'zephyr_realm')
|
||||
|
||||
# Deleting model 'UserProfile'
|
||||
db.delete_table('zephyr_userprofile')
|
||||
db.delete_table(u'zephyr_userprofile')
|
||||
|
||||
# Deleting model 'PreregistrationUser'
|
||||
db.delete_table('zephyr_preregistrationuser')
|
||||
db.delete_table(u'zephyr_preregistrationuser')
|
||||
|
||||
# Removing M2M table for field streams on 'PreregistrationUser'
|
||||
db.delete_table('zephyr_preregistrationuser_streams')
|
||||
|
||||
# Deleting model 'MitUser'
|
||||
db.delete_table('zephyr_mituser')
|
||||
db.delete_table(u'zephyr_mituser')
|
||||
|
||||
# Deleting model 'Stream'
|
||||
db.delete_table('zephyr_stream')
|
||||
db.delete_table(u'zephyr_stream')
|
||||
|
||||
# Deleting model 'Recipient'
|
||||
db.delete_table('zephyr_recipient')
|
||||
db.delete_table(u'zephyr_recipient')
|
||||
|
||||
# Deleting model 'Client'
|
||||
db.delete_table('zephyr_client')
|
||||
db.delete_table(u'zephyr_client')
|
||||
|
||||
# Deleting model 'Message'
|
||||
db.delete_table('zephyr_message')
|
||||
db.delete_table(u'zephyr_message')
|
||||
|
||||
# Deleting model 'UserMessage'
|
||||
db.delete_table('zephyr_usermessage')
|
||||
db.delete_table(u'zephyr_usermessage')
|
||||
|
||||
# Deleting model 'Subscription'
|
||||
db.delete_table('zephyr_subscription')
|
||||
db.delete_table(u'zephyr_subscription')
|
||||
|
||||
# Deleting model 'Huddle'
|
||||
db.delete_table('zephyr_huddle')
|
||||
db.delete_table(u'zephyr_huddle')
|
||||
|
||||
# Deleting model 'UserActivity'
|
||||
db.delete_table('zephyr_useractivity')
|
||||
db.delete_table(u'zephyr_useractivity')
|
||||
|
||||
# Deleting model 'UserPresence'
|
||||
db.delete_table(u'zephyr_userpresence')
|
||||
|
||||
# Deleting model 'DefaultStream'
|
||||
db.delete_table('zephyr_defaultstream')
|
||||
db.delete_table(u'zephyr_defaultstream')
|
||||
|
||||
# Deleting model 'StreamColor'
|
||||
db.delete_table('zephyr_streamcolor')
|
||||
db.delete_table(u'zephyr_streamcolor')
|
||||
|
||||
|
||||
models = {
|
||||
'auth.group': {
|
||||
'Meta': {'object_name': 'Group'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
|
||||
'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
|
||||
},
|
||||
'auth.permission': {
|
||||
'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
|
||||
'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
|
||||
},
|
||||
'auth.user': {
|
||||
'Meta': {'object_name': 'User'},
|
||||
'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
|
||||
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
|
||||
'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
|
||||
'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
||||
'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
||||
'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
||||
'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
|
||||
'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
|
||||
'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
||||
'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
|
||||
'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
|
||||
},
|
||||
'contenttypes.contenttype': {
|
||||
'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
|
||||
'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
|
||||
},
|
||||
'zephyr.client': {
|
||||
u'zephyr.client': {
|
||||
'Meta': {'object_name': 'Client'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30', 'db_index': 'True'})
|
||||
},
|
||||
'zephyr.defaultstream': {
|
||||
u'zephyr.defaultstream': {
|
||||
'Meta': {'unique_together': "(('realm', 'stream'),)", 'object_name': 'DefaultStream'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Realm']"}),
|
||||
'stream': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Stream']"})
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Realm']"}),
|
||||
'stream': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Stream']"})
|
||||
},
|
||||
'zephyr.huddle': {
|
||||
u'zephyr.huddle': {
|
||||
'Meta': {'object_name': 'Huddle'},
|
||||
'huddle_hash': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'})
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'})
|
||||
},
|
||||
'zephyr.message': {
|
||||
u'zephyr.message': {
|
||||
'Meta': {'object_name': 'Message'},
|
||||
'content': ('django.db.models.fields.TextField', [], {}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'pub_date': ('django.db.models.fields.DateTimeField', [], {'db_index': 'True'}),
|
||||
'recipient': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Recipient']"}),
|
||||
'sender': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"}),
|
||||
'sending_client': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Client']"}),
|
||||
'recipient': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Recipient']"}),
|
||||
'rendered_content': ('django.db.models.fields.TextField', [], {'null': 'True'}),
|
||||
'rendered_content_version': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
|
||||
'sender': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.UserProfile']"}),
|
||||
'sending_client': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Client']"}),
|
||||
'subject': ('django.db.models.fields.CharField', [], {'max_length': '60', 'db_index': 'True'})
|
||||
},
|
||||
'zephyr.mituser': {
|
||||
u'zephyr.mituser': {
|
||||
'Meta': {'object_name': 'MitUser'},
|
||||
'email': ('django.db.models.fields.EmailField', [], {'unique': 'True', 'max_length': '75'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'status': ('django.db.models.fields.IntegerField', [], {'default': '0'})
|
||||
},
|
||||
'zephyr.preregistrationuser': {
|
||||
u'zephyr.preregistrationuser': {
|
||||
'Meta': {'object_name': 'PreregistrationUser'},
|
||||
'email': ('django.db.models.fields.EmailField', [], {'unique': 'True', 'max_length': '75'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'status': ('django.db.models.fields.IntegerField', [], {'default': '0'})
|
||||
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'invited_at': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
|
||||
'referred_by': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.UserProfile']", 'null': 'True'}),
|
||||
'status': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
|
||||
'streams': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['zephyr.Stream']", 'null': 'True', 'symmetrical': 'False'})
|
||||
},
|
||||
'zephyr.realm': {
|
||||
u'zephyr.realm': {
|
||||
'Meta': {'object_name': 'Realm'},
|
||||
'domain': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '40', 'db_index': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'})
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'restricted_to_domain': ('django.db.models.fields.BooleanField', [], {'default': 'True'})
|
||||
},
|
||||
'zephyr.recipient': {
|
||||
u'zephyr.recipient': {
|
||||
'Meta': {'unique_together': "(('type', 'type_id'),)", 'object_name': 'Recipient'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'type': ('django.db.models.fields.PositiveSmallIntegerField', [], {'db_index': 'True'}),
|
||||
'type_id': ('django.db.models.fields.IntegerField', [], {'db_index': 'True'})
|
||||
},
|
||||
'zephyr.stream': {
|
||||
u'zephyr.stream': {
|
||||
'Meta': {'unique_together': "(('name', 'realm'),)", 'object_name': 'Stream'},
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'invite_only': ('django.db.models.fields.NullBooleanField', [], {'default': 'False', 'null': 'True', 'blank': 'True'}),
|
||||
'name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'db_index': 'True'}),
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Realm']"})
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Realm']"})
|
||||
},
|
||||
'zephyr.streamcolor': {
|
||||
u'zephyr.streamcolor': {
|
||||
'Meta': {'object_name': 'StreamColor'},
|
||||
'color': ('django.db.models.fields.CharField', [], {'max_length': '10'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'subscription': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Subscription']"})
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'subscription': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Subscription']"})
|
||||
},
|
||||
'zephyr.subscription': {
|
||||
u'zephyr.subscription': {
|
||||
'Meta': {'unique_together': "(('user_profile', 'recipient'),)", 'object_name': 'Subscription'},
|
||||
'active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'recipient': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Recipient']"}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"})
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'in_home_view': ('django.db.models.fields.NullBooleanField', [], {'default': 'True', 'null': 'True', 'blank': 'True'}),
|
||||
'recipient': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Recipient']"}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.UserProfile']"})
|
||||
},
|
||||
'zephyr.useractivity': {
|
||||
u'zephyr.useractivity': {
|
||||
'Meta': {'unique_together': "(('user_profile', 'client', 'query'),)", 'object_name': 'UserActivity'},
|
||||
'client': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Client']"}),
|
||||
'client': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Client']"}),
|
||||
'count': ('django.db.models.fields.IntegerField', [], {}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'last_visit': ('django.db.models.fields.DateTimeField', [], {}),
|
||||
'query': ('django.db.models.fields.CharField', [], {'max_length': '50', 'db_index': 'True'}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"})
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.UserProfile']"})
|
||||
},
|
||||
'zephyr.usermessage': {
|
||||
u'zephyr.usermessage': {
|
||||
'Meta': {'unique_together': "(('user_profile', 'message'),)", 'object_name': 'UserMessage'},
|
||||
'archived': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'message': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Message']"}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.UserProfile']"})
|
||||
'flags': ('django.db.models.fields.BigIntegerField', [], {'default': '0'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'message': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Message']"}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.UserProfile']"})
|
||||
},
|
||||
'zephyr.userprofile': {
|
||||
u'zephyr.userpresence': {
|
||||
'Meta': {'unique_together': "(('user_profile', 'client'),)", 'object_name': 'UserPresence'},
|
||||
'client': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Client']"}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'status': ('django.db.models.fields.PositiveSmallIntegerField', [], {'default': '1'}),
|
||||
'timestamp': ('django.db.models.fields.DateTimeField', [], {}),
|
||||
'user_profile': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.UserProfile']"})
|
||||
},
|
||||
u'zephyr.userprofile': {
|
||||
'Meta': {'object_name': 'UserProfile'},
|
||||
'api_key': ('django.db.models.fields.CharField', [], {'max_length': '32'}),
|
||||
'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
|
||||
'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
|
||||
'enable_desktop_notifications': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
||||
'enter_sends': ('django.db.models.fields.NullBooleanField', [], {'default': 'False', 'null': 'True', 'blank': 'True'}),
|
||||
'full_name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
||||
'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
||||
'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
||||
'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
|
||||
'last_pointer_updater': ('django.db.models.fields.CharField', [], {'max_length': '64'}),
|
||||
'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
||||
'pointer': ('django.db.models.fields.IntegerField', [], {}),
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['zephyr.Realm']"}),
|
||||
'short_name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
||||
'user': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True'})
|
||||
'realm': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['zephyr.Realm']"}),
|
||||
'short_name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
|
||||
}
|
||||
}
|
||||
|
||||
complete_apps = ['zephyr']
|
||||
complete_apps = ['zephyr']
|
||||
|
|
Loading…
Reference in New Issue