-# encoding: utf-8\r
-import datetime\r
-from south.db import db\r
-from south.v2 import DataMigration\r
-from django.db import models\r
-from forum.migrations import ProgressBar\r
-\r
-GAIN_BY_UPVOTED = 1\r
-GAIN_BY_ANSWER_ACCEPTED = 2\r
-GAIN_BY_ACCEPTING_ANSWER = 3\r
-GAIN_BY_DOWNVOTE_CANCELED = 4\r
-GAIN_BY_CANCELING_DOWNVOTE = 5\r
-LOST_BY_CANCELLING_ACCEPTED_ANSWER = -1\r
-LOST_BY_ACCEPTED_ANSWER_CANCELED = -2\r
-LOST_BY_DOWNVOTED = -3\r
-LOST_BY_FLAGGED = -4\r
-LOST_BY_DOWNVOTING = -5\r
-LOST_BY_FLAGGED_3_TIMES = -6\r
-LOST_BY_FLAGGED_5_TIMES = -7\r
-LOST_BY_UPVOTE_CANCELED = -8\r
-\r
-class Migration(DataMigration):\r
- \r
- def forwards(self, orm):\r
- rephist = dict([(t, []) for t in range(-8, 6) if t != 0])\r
-\r
- r_count = orm.Repute.objects.count()\r
- print "\nCalculating rep gain/losses history through %d records:" % r_count\r
- progress = ProgressBar(r_count)\r
-\r
- for r in orm.Repute.objects.all():\r
- l = rephist.get(r.reputation_type, None)\r
- if l is None: continue\r
-\r
- if (len(l) == 0) or (l[-1][1] != r.value):\r
- l.append((r.reputed_at, r.value))\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
-\r
- def repval_at(reptype, repdate, default):\r
- l = rephist.get(reptype, None)\r
-\r
- if l is None: return 0\r
- if len(l) == 0: return default\r
-\r
- for r in l:\r
- if r[0] <= repdate:\r
- return r[1] or default\r
-\r
-\r
- q_count = orm.Question.objects.count()\r
- print "\nConverting %d questions:" % q_count\r
- progress = ProgressBar(q_count)\r
-\r
- for q in orm.Question.objects.all():\r
- n = q.node_ptr\r
- n.last_activity_at = q.last_activity_at\r
- n.last_activity_by = q.last_activity_by\r
-\r
- if q.accepted_answer:\r
- n.extra_ref = q.accepted_answer.node_ptr\r
- \r
- n.extra_count = q.view_count\r
-\r
- n.marked = q.closed\r
- n.wiki = q.wiki\r
-\r
- n.save()\r
-\r
- ask = orm.Action(\r
- user = n.author,\r
- action_date = n.added_at,\r
- node = n,\r
- action_type = "ask",\r
- extra = ''\r
- )\r
-\r
- ask.save()\r
-\r
- if n.deleted:\r
- action = orm.Action(\r
- user = n.deleted_by,\r
- node = n,\r
- action_type = "delete",\r
- action_date = n.deleted_at or datetime.datetime.now(),\r
- extra = ''\r
- )\r
-\r
- action.save()\r
-\r
-\r
- if n.marked:\r
- action = orm.Action(\r
- user = q.closed_by,\r
- node = n,\r
- action_type = "close",\r
- extra = q.close_reason,\r
- action_date = q.closed_at or datetime.datetime.now(),\r
- )\r
-\r
- action.save()\r
-\r
- if n.wiki:\r
- action = orm.Action(\r
- user = n.author,\r
- node = n,\r
- action_type = "wikify",\r
- action_date = q.wikified_at or datetime.datetime.now(),\r
- extra = ''\r
- )\r
-\r
- action.save()\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
- a_count = orm.Answer.objects.count()\r
- print "\nConverting %d answers:" % a_count\r
- progress = ProgressBar(a_count)\r
-\r
- for a in orm.Answer.objects.all():\r
- n = a.node_ptr\r
-\r
- n.marked = a.accepted\r
- n.wiki = a.wiki\r
-\r
- n.save()\r
-\r
- ans = orm.Action(\r
- user = n.author,\r
- action_date = n.added_at,\r
- node = n,\r
- action_type = "answer",\r
- extra = ''\r
- )\r
-\r
- ans.save()\r
-\r
- if n.deleted:\r
- action = orm.Action(\r
- user = n.deleted_by,\r
- node = n,\r
- action_type = "delete",\r
- action_date = n.deleted_at or datetime.datetime.now(),\r
- extra = ''\r
- )\r
-\r
- action.save()\r
-\r
- if a.accepted:\r
- action = orm.Action(\r
- user = a.accepted_by,\r
- node = n,\r
- action_type = "acceptanswer",\r
- action_date = a.accepted_at or datetime.datetime.now(),\r
- extra = ''\r
- )\r
-\r
- action.save()\r
-\r
- if not a.wiki or a.wikified_at > action.action_date:\r
- if action.user == n.author:\r
- rep = orm.ActionRepute(\r
- action = action,\r
- user = action.user,\r
- value = repval_at(GAIN_BY_ACCEPTING_ANSWER, action.action_date, 2)\r
- )\r
- rep.save()\r
-\r
- if n.author != n.parent.author:\r
- rep = orm.ActionRepute(\r
- action = action,\r
- user = n.author,\r
- value = repval_at(GAIN_BY_ANSWER_ACCEPTED, action.action_date, 15)\r
- )\r
- rep.save()\r
-\r
- if n.wiki:\r
- action = orm.Action(\r
- user = n.author,\r
- node = n,\r
- action_type = "wikify",\r
- action_date = a.wikified_at or datetime.datetime.now(),\r
- extra = ''\r
- )\r
-\r
- action.save()\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
- v_count = orm.Vote.objects.count()\r
- print "\nConverting %d votes:" % v_count\r
- progress = ProgressBar(v_count)\r
-\r
- for v in orm.Vote.objects.exclude(canceled=True):\r
- a = orm.Action(\r
- action_type = (v.vote == 1) and ((v.node.node_type == "comment") and "voteupcomment" or "voteup") or "votedown",\r
- user = v.user,\r
- node = v.node,\r
- action_date = v.voted_at,\r
- canceled = v.canceled,\r
- extra = ''\r
- )\r
-\r
- a.save()\r
-\r
- def impl(node):\r
- if node.node_type == "question":\r
- return orm.Question.objects.get(node_ptr=node)\r
- else:\r
- return orm.Answer.objects.get(node_ptr=node)\r
-\r
- if a.node.node_type in ("question", "answer") and (not a.node.wiki or impl(a.node).wikified_at > a.action_date):\r
- reptype, default = (v.vote == 1) and (GAIN_BY_UPVOTED, 10) or (LOST_BY_DOWNVOTED, 2)\r
- rep = orm.ActionRepute(\r
- action = a,\r
- user = a.node.author,\r
- value = repval_at(reptype, a.action_date, default) or default\r
- )\r
- rep.save()\r
-\r
- if v.vote == -1:\r
- rep = orm.ActionRepute(\r
- action = a,\r
- user = a.node.author,\r
- value = repval_at(LOST_BY_DOWNVOTING, a.action_date, 1) or default\r
- )\r
- rep.save()\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
- f_count = orm.FlaggedItem.objects.count()\r
- print "\nConverting %d flags:" % f_count\r
- progress = ProgressBar(f_count)\r
-\r
- for f in orm.FlaggedItem.objects.all():\r
- a = orm.Action(\r
- action_type = "flag",\r
- user = f.user,\r
- node = f.node,\r
- action_date = f.flagged_at,\r
- extra = f.reason or ''\r
- )\r
-\r
- a.save()\r
-\r
- rep = orm.ActionRepute(\r
- action = a,\r
- user = a.node.author,\r
- value = repval_at(LOST_BY_FLAGGED, a.action_date, 2) or 2\r
- )\r
- rep.save()\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
- n_count = orm.Node.objects.all().count()\r
- print "\nChecking flag count of %d nodes:" % n_count\r
- progress = ProgressBar(n_count)\r
-\r
- for n in orm.Node.objects.all():\r
- flags = list(orm.Action.objects.filter(action_type="flag", node=n, canceled=False).order_by('-action_date'))\r
-\r
- if len(flags) >= 3:\r
- a = flags[2]\r
- rep = orm.ActionRepute(\r
- action = a,\r
- user = n.author,\r
- value = repval_at(LOST_BY_FLAGGED_3_TIMES, a.action_date, 30)\r
- )\r
- rep.save()\r
-\r
-\r
- if len(flags) >= 5:\r
- a = flags[4]\r
- rep = orm.ActionRepute(\r
- action = a,\r
- user = n.author,\r
- value = repval_at(LOST_BY_FLAGGED_5_TIMES, a.action_date, 100)\r
- )\r
- rep.save()\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
- c_count = orm.Node.objects.filter(node_type="comment").count()\r
- print "\nCreating %d comment actions:" % c_count\r
- progress = ProgressBar(c_count)\r
-\r
- for c in orm.Node.objects.filter(node_type="comment").all():\r
- a = orm.Action(\r
- action_type = "comment",\r
- user = c.author,\r
- node = c,\r
- action_date = c.added_at,\r
- extra = ''\r
- )\r
-\r
- a.save()\r
-\r
- if c.deleted:\r
- action = orm.Action(\r
- user = c.deleted_by,\r
- node = c,\r
- action_type = "delete",\r
- action_date = c.deleted_at or datetime.datetime.now(),\r
- extra = ''\r
- )\r
-\r
- action.save()\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
-\r
- r_count = orm.NodeRevision.objects.exclude(revision=1).count()\r
- print "\nCreating %d edit actions:" % r_count\r
- progress = ProgressBar(r_count)\r
-\r
- for r in orm.NodeRevision.objects.exclude(revision=1):\r
- a = orm.Action(\r
- action_type = "revise",\r
- user = r.author,\r
- node = r.node,\r
- action_date = r.revised_at,\r
- extra = r.revision\r
- )\r
-\r
- a.save()\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
- u_count = orm.User.objects.all().count()\r
- print "\nCreating %d user join actions and reputation recalculation:" % u_count\r
- progress = ProgressBar(u_count)\r
-\r
- for u in orm.User.objects.all():\r
- a = orm.Action(\r
- user = u,\r
- action_date = u.date_joined,\r
- action_type = "userjoins",\r
- )\r
-\r
- a.save()\r
-\r
- rep = orm.ActionRepute(\r
- action = a,\r
- user = u,\r
- value = 1\r
- )\r
- rep.save()\r
-\r
- new_rep = orm.ActionRepute.objects.filter(user=u).aggregate(reputation=models.Sum('value'))['reputation']\r
-\r
- if new_rep < 0:\r
- new_rep = 1\r
-\r
- u.reputation = new_rep\r
- u.save()\r
-\r
- progress.update()\r
-\r
- print "\n...done\n"\r
-\r
- \r
- \r
- def backwards(self, orm):\r
- "Write your backwards methods here."\r
- \r
- models = {\r
- 'auth.group': {\r
- 'Meta': {'object_name': 'Group'},\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),\r
- 'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'blank': 'True'})\r
- },\r
- 'auth.permission': {\r
- 'Meta': {'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},\r
- 'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),\r
- 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})\r
- },\r
- 'auth.user': {\r
- 'Meta': {'object_name': 'User'},\r
- 'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),\r
- 'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),\r
- 'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'blank': 'True'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),\r
- 'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),\r
- 'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'blank': 'True'}),\r
- 'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})\r
- },\r
- 'contenttypes.contenttype': {\r
- 'Meta': {'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},\r
- 'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),\r
- 'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})\r
- },\r
- 'forum.action': {\r
- 'Meta': {'object_name': 'Action'},\r
- 'action_date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'action_type': ('django.db.models.fields.CharField', [], {'max_length': '16'}),\r
- 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'canceled_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}),\r
- 'canceled_by': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'canceled_actions'", 'null': 'True', 'to': "orm['forum.User']"}),\r
- 'extra': ('django.db.models.fields.CharField', [], {'max_length': '255'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'ip': ('django.db.models.fields.CharField', [], {'max_length': '16'}),\r
- 'node': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True'}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'actions'", 'to': "orm['forum.User']"})\r
- },\r
- 'forum.actionrepute': {\r
- 'Meta': {'object_name': 'ActionRepute'},\r
- 'action': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'reputes'", 'to': "orm['forum.Action']"}),\r
- 'by_canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"}),\r
- 'value': ('django.db.models.fields.IntegerField', [], {'default': '0'})\r
- },\r
- 'forum.activity': {\r
- 'Meta': {'object_name': 'Activity', 'db_table': "u'activity'"},\r
- 'active_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'activity_type': ('django.db.models.fields.SmallIntegerField', [], {}),\r
- 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'is_auditted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'object_id': ('django.db.models.fields.PositiveIntegerField', [], {}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"})\r
- },\r
- 'forum.anonymousnode': {\r
- 'Meta': {'object_name': 'AnonymousNode', '_ormbases': ['forum.Node']},\r
- 'convertible_to': ('django.db.models.fields.CharField', [], {'default': "'node'", 'max_length': '16'}),\r
- 'node_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['forum.Node']", 'unique': 'True', 'primary_key': 'True'}),\r
- 'validation_hash': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'anonymous_content'", 'to': "orm['forum.Node']"})\r
- },\r
- 'forum.answer': {\r
- 'Meta': {'object_name': 'Answer', 'db_table': "u'answer'"},\r
- 'accepted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'accepted_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),\r
- 'accepted_by': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']", 'null': 'True'}),\r
- 'node_ptr': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True', 'primary_key': 'True'}),\r
- 'wiki': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'wikified_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'})\r
- },\r
- 'forum.authkeyuserassociation': {\r
- 'Meta': {'object_name': 'AuthKeyUserAssociation'},\r
- 'added_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),\r
- 'provider': ('django.db.models.fields.CharField', [], {'max_length': '64'}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'auth_keys'", 'to': "orm['forum.User']"})\r
- },\r
- 'forum.award': {\r
- 'Meta': {'object_name': 'Award', 'db_table': "u'award'"},\r
- 'awarded_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'badge': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'award_badge'", 'to': "orm['forum.Badge']"}),\r
- 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'notified': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'object_id': ('django.db.models.fields.PositiveIntegerField', [], {}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'awards'", 'to': "orm['forum.User']"})\r
- },\r
- 'forum.badge': {\r
- 'Meta': {'unique_together': "(('name', 'type'),)", 'object_name': 'Badge', 'db_table': "u'badge'"},\r
- 'awarded_count': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),\r
- 'awarded_to': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'badges'", 'through': "'Award'", 'to': "orm['forum.User']"}),\r
- 'description': ('django.db.models.fields.CharField', [], {'max_length': '300'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'multiple': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),\r
- 'slug': ('django.db.models.fields.SlugField', [], {'db_index': 'True', 'max_length': '50', 'blank': 'True'}),\r
- 'type': ('django.db.models.fields.SmallIntegerField', [], {})\r
- },\r
- 'forum.favoritequestion': {\r
- 'Meta': {'unique_together': "(('question', 'user'),)", 'object_name': 'FavoriteQuestion', 'db_table': "u'favorite_question'"},\r
- 'added_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'question': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'favourites'", 'to': "orm['forum.Question']"}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'user_favorite_questions'", 'to': "orm['forum.User']"})\r
- },\r
- 'forum.flaggeditem': {\r
- 'Meta': {'object_name': 'FlaggedItem', 'db_table': "u'flagged_item'"},\r
- 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'flagged_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'flaggeditems'", 'null': 'True', 'to': "orm['forum.Node']"}),\r
- 'reason': ('django.db.models.fields.CharField', [], {'max_length': '300', 'null': 'True'}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'flaggeditems'", 'to': "orm['forum.User']"})\r
- },\r
- 'forum.keyvalue': {\r
- 'Meta': {'object_name': 'KeyValue'},\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),\r
- 'value': ('forum.models.utils.PickledObjectField', [], {})\r
- },\r
- 'forum.markedtag': {\r
- 'Meta': {'object_name': 'MarkedTag'},\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'reason': ('django.db.models.fields.CharField', [], {'max_length': '16'}),\r
- 'tag': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'user_selections'", 'to': "orm['forum.Tag']"}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'tag_selections'", 'to': "orm['forum.User']"})\r
- },\r
- 'forum.node': {\r
- 'Meta': {'object_name': 'Node'},\r
- 'abs_parent': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'all_children'", 'null': 'True', 'to': "orm['forum.Node']"}),\r
- 'active_revision': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'active'", 'unique': 'True', 'null': 'True', 'to': "orm['forum.NodeRevision']"}),\r
- 'added_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'author': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nodes'", 'to': "orm['forum.User']"}),\r
- 'body': ('django.db.models.fields.TextField', [], {}),\r
- 'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'deleted_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),\r
- 'deleted_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'deleted_nodes'", 'null': 'True', 'to': "orm['forum.User']"}),\r
- 'extra_count': ('django.db.models.fields.IntegerField', [], {'default': '0'}),\r
- 'extra_ref': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'last_activity_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),\r
- 'last_activity_by': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']", 'null': 'True'}),\r
- 'last_edited_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),\r
- 'last_edited_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'last_edited_nodes'", 'null': 'True', 'to': "orm['forum.User']"}),\r
- 'marked': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'node_type': ('django.db.models.fields.CharField', [], {'default': "'node'", 'max_length': '16'}),\r
- 'parent': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'children'", 'null': 'True', 'to': "orm['forum.Node']"}),\r
- 'score': ('django.db.models.fields.IntegerField', [], {'default': '0'}),\r
- 'tagnames': ('django.db.models.fields.CharField', [], {'max_length': '125'}),\r
- 'tags': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'nodes'", 'to': "orm['forum.Tag']"}),\r
- 'title': ('django.db.models.fields.CharField', [], {'max_length': '300'}),\r
- 'wiki': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'})\r
- },\r
- 'forum.noderevision': {\r
- 'Meta': {'unique_together': "(('node', 'revision'),)", 'object_name': 'NodeRevision'},\r
- 'author': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'noderevisions'", 'to': "orm['forum.User']"}),\r
- 'body': ('django.db.models.fields.TextField', [], {}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'revisions'", 'to': "orm['forum.Node']"}),\r
- 'revised_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'revision': ('django.db.models.fields.PositiveIntegerField', [], {}),\r
- 'summary': ('django.db.models.fields.CharField', [], {'max_length': '300'}),\r
- 'tagnames': ('django.db.models.fields.CharField', [], {'max_length': '125'}),\r
- 'title': ('django.db.models.fields.CharField', [], {'max_length': '300'})\r
- },\r
- 'forum.openidassociation': {\r
- 'Meta': {'object_name': 'OpenIdAssociation'},\r
- 'assoc_type': ('django.db.models.fields.TextField', [], {'max_length': '64'}),\r
- 'handle': ('django.db.models.fields.CharField', [], {'max_length': '255'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'issued': ('django.db.models.fields.IntegerField', [], {}),\r
- 'lifetime': ('django.db.models.fields.IntegerField', [], {}),\r
- 'secret': ('django.db.models.fields.TextField', [], {'max_length': '255'}),\r
- 'server_url': ('django.db.models.fields.TextField', [], {'max_length': '2047'})\r
- },\r
- 'forum.openidnonce': {\r
- 'Meta': {'object_name': 'OpenIdNonce'},\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'salt': ('django.db.models.fields.CharField', [], {'max_length': '50'}),\r
- 'server_url': ('django.db.models.fields.URLField', [], {'max_length': '200'}),\r
- 'timestamp': ('django.db.models.fields.IntegerField', [], {})\r
- },\r
- 'forum.question': {\r
- 'Meta': {'object_name': 'Question', 'db_table': "u'question'"},\r
- 'accepted_answer': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'question_accepting'", 'unique': 'True', 'null': 'True', 'to': "orm['forum.Answer']"}),\r
- 'close_reason': ('django.db.models.fields.SmallIntegerField', [], {'null': 'True', 'blank': 'True'}),\r
- 'closed': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'closed_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),\r
- 'closed_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'closed_questions'", 'null': 'True', 'to': "orm['forum.User']"}),\r
- 'favorited_by': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'favorite_questions'", 'through': "'FavoriteQuestion'", 'to': "orm['forum.User']"}),\r
- 'last_activity_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'last_activity_by': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'last_active_in_questions'", 'null': 'True', 'to': "orm['forum.User']"}),\r
- 'node_ptr': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True', 'primary_key': 'True'}),\r
- 'view_count': ('django.db.models.fields.IntegerField', [], {'default': '0'}),\r
- 'wiki': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'wikified_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'})\r
- },\r
- 'forum.questionsubscription': {\r
- 'Meta': {'object_name': 'QuestionSubscription'},\r
- 'auto_subscription': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'last_view': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2010, 4, 27, 11, 40, 32, 68000)'}),\r
- 'question': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']"}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"})\r
- },\r
- 'forum.repute': {\r
- 'Meta': {'object_name': 'Repute', 'db_table': "u'repute'"},\r
- 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'reputes'", 'null': 'True', 'to': "orm['forum.Node']"}),\r
- 'question': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Question']"}),\r
- 'reputation_type': ('django.db.models.fields.SmallIntegerField', [], {}),\r
- 'reputed_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'reputes'", 'to': "orm['forum.User']"}),\r
- 'user_previous_rep': ('django.db.models.fields.IntegerField', [], {'default': '0'}),\r
- 'value': ('django.db.models.fields.SmallIntegerField', [], {'default': '0'})\r
- },\r
- 'forum.subscriptionsettings': {\r
- 'Meta': {'object_name': 'SubscriptionSettings'},\r
- 'all_questions': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'all_questions_watched_tags': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'enable_notifications': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'member_joins': ('django.db.models.fields.CharField', [], {'default': "'n'", 'max_length': '1'}),\r
- 'new_question': ('django.db.models.fields.CharField', [], {'default': "'d'", 'max_length': '1'}),\r
- 'new_question_watched_tags': ('django.db.models.fields.CharField', [], {'default': "'i'", 'max_length': '1'}),\r
- 'notify_accepted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'notify_answers': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'notify_comments': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'notify_comments_own_post': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'notify_reply_to_comments': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'questions_answered': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'questions_asked': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),\r
- 'questions_commented': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'questions_viewed': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'subscribed_questions': ('django.db.models.fields.CharField', [], {'default': "'i'", 'max_length': '1'}),\r
- 'user': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'subscription_settings'", 'unique': 'True', 'to': "orm['forum.User']"})\r
- },\r
- 'forum.tag': {\r
- 'Meta': {'object_name': 'Tag', 'db_table': "u'tag'"},\r
- 'created_by': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'created_tags'", 'to': "orm['forum.User']"}),\r
- 'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'deleted_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),\r
- 'deleted_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'deleted_tags'", 'null': 'True', 'to': "orm['forum.User']"}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'marked_by': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'marked_tags'", 'through': "'MarkedTag'", 'to': "orm['forum.User']"}),\r
- 'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),\r
- 'used_count': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'})\r
- },\r
- 'forum.user': {\r
- 'Meta': {'object_name': 'User', '_ormbases': ['auth.User']},\r
- 'about': ('django.db.models.fields.TextField', [], {'blank': 'True'}),\r
- 'bronze': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),\r
- 'date_of_birth': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),\r
- 'email_isvalid': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'email_key': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),\r
- 'gold': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),\r
- 'hide_ignored_questions': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'is_approved': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'last_seen': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),\r
- 'location': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),\r
- 'questions_per_page': ('django.db.models.fields.SmallIntegerField', [], {'default': '10'}),\r
- 'real_name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),\r
- 'reputation': ('django.db.models.fields.PositiveIntegerField', [], {'default': '1'}),\r
- 'silver': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),\r
- 'subscriptions': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'subscribers'", 'through': "'QuestionSubscription'", 'to': "orm['forum.Node']"}),\r
- 'user_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True', 'primary_key': 'True'}),\r
- 'website': ('django.db.models.fields.URLField', [], {'max_length': '200', 'blank': 'True'})\r
- },\r
- 'forum.validationhash': {\r
- 'Meta': {'unique_together': "(('user', 'type'),)", 'object_name': 'ValidationHash'},\r
- 'expiration': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2010, 4, 28, 11, 40, 32, 153000)'}),\r
- 'hash_code': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'seed': ('django.db.models.fields.CharField', [], {'max_length': '12'}),\r
- 'type': ('django.db.models.fields.CharField', [], {'max_length': '12'}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"})\r
- },\r
- 'forum.vote': {\r
- 'Meta': {'object_name': 'Vote', 'db_table': "u'vote'"},\r
- 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),\r
- 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),\r
- 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'votes'", 'null': 'True', 'to': "orm['forum.Node']"}),\r
- 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'votes'", 'to': "orm['forum.User']"}),\r
- 'vote': ('django.db.models.fields.SmallIntegerField', [], {}),\r
- 'voted_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'})\r
- }\r
- }\r
- \r
- complete_apps = ['forum']\r
+# encoding: utf-8
+import datetime
+from south.db import db
+from south.v2 import DataMigration
+from django.db import models
+from forum.migrations import ProgressBar
+
+GAIN_BY_UPVOTED = 1
+GAIN_BY_ANSWER_ACCEPTED = 2
+GAIN_BY_ACCEPTING_ANSWER = 3
+GAIN_BY_DOWNVOTE_CANCELED = 4
+GAIN_BY_CANCELING_DOWNVOTE = 5
+LOST_BY_CANCELLING_ACCEPTED_ANSWER = -1
+LOST_BY_ACCEPTED_ANSWER_CANCELED = -2
+LOST_BY_DOWNVOTED = -3
+LOST_BY_FLAGGED = -4
+LOST_BY_DOWNVOTING = -5
+LOST_BY_FLAGGED_3_TIMES = -6
+LOST_BY_FLAGGED_5_TIMES = -7
+LOST_BY_UPVOTE_CANCELED = -8
+
+class Migration(DataMigration):
+
+ def forwards(self, orm):
+ rephist = dict([(t, []) for t in range(-8, 6) if t != 0])
+
+ r_count = orm.Repute.objects.count()
+ print "\nCalculating rep gain/losses history through %d records:" % r_count
+ progress = ProgressBar(r_count)
+
+ for r in orm.Repute.objects.all():
+ l = rephist.get(r.reputation_type, None)
+ if l is None: continue
+
+ if (len(l) == 0) or (l[-1][1] != r.value):
+ l.append((r.reputed_at, r.value))
+
+ progress.update()
+
+ print "\n...done\n"
+
+
+ def repval_at(reptype, repdate, default):
+ l = rephist.get(reptype, None)
+
+ if l is None: return 0
+ if len(l) == 0: return default
+
+ for r in l:
+ if r[0] <= repdate:
+ return r[1] or default
+
+
+ q_count = orm.Question.objects.count()
+ print "\nConverting %d questions:" % q_count
+ progress = ProgressBar(q_count)
+
+ for q in orm.Question.objects.all():
+ n = q.node_ptr
+ n.last_activity_at = q.last_activity_at
+ n.last_activity_by = q.last_activity_by
+
+ if q.accepted_answer:
+ n.extra_ref = q.accepted_answer.node_ptr
+
+ n.extra_count = q.view_count
+
+ n.marked = q.closed
+ n.wiki = q.wiki
+
+ n.save()
+
+ ask = orm.Action(
+ user = n.author,
+ action_date = n.added_at,
+ node = n,
+ action_type = "ask",
+ extra = ''
+ )
+
+ ask.save()
+
+ if n.deleted:
+ action = orm.Action(
+ user = n.deleted_by,
+ node = n,
+ action_type = "delete",
+ action_date = n.deleted_at or datetime.datetime.now(),
+ extra = ''
+ )
+
+ action.save()
+
+
+ if n.marked:
+ action = orm.Action(
+ user = q.closed_by,
+ node = n,
+ action_type = "close",
+ extra = q.close_reason,
+ action_date = q.closed_at or datetime.datetime.now(),
+ )
+
+ action.save()
+
+ if n.wiki:
+ action = orm.Action(
+ user = n.author,
+ node = n,
+ action_type = "wikify",
+ action_date = q.wikified_at or datetime.datetime.now(),
+ extra = ''
+ )
+
+ action.save()
+
+ progress.update()
+
+ print "\n...done\n"
+
+ a_count = orm.Answer.objects.count()
+ print "\nConverting %d answers:" % a_count
+ progress = ProgressBar(a_count)
+
+ for a in orm.Answer.objects.all():
+ n = a.node_ptr
+
+ n.marked = a.accepted
+ n.wiki = a.wiki
+
+ n.save()
+
+ ans = orm.Action(
+ user = n.author,
+ action_date = n.added_at,
+ node = n,
+ action_type = "answer",
+ extra = ''
+ )
+
+ ans.save()
+
+ if n.deleted:
+ action = orm.Action(
+ user = n.deleted_by,
+ node = n,
+ action_type = "delete",
+ action_date = n.deleted_at or datetime.datetime.now(),
+ extra = ''
+ )
+
+ action.save()
+
+ if a.accepted:
+ action = orm.Action(
+ user = a.accepted_by,
+ node = n,
+ action_type = "acceptanswer",
+ action_date = a.accepted_at or datetime.datetime.now(),
+ extra = ''
+ )
+
+ action.save()
+
+ if not a.wiki or a.wikified_at > action.action_date:
+ if action.user == n.author:
+ rep = orm.ActionRepute(
+ action = action,
+ user = action.user,
+ value = repval_at(GAIN_BY_ACCEPTING_ANSWER, action.action_date, 2)
+ )
+ rep.save()
+
+ if n.author != n.parent.author:
+ rep = orm.ActionRepute(
+ action = action,
+ user = n.author,
+ value = repval_at(GAIN_BY_ANSWER_ACCEPTED, action.action_date, 15)
+ )
+ rep.save()
+
+ if n.wiki:
+ action = orm.Action(
+ user = n.author,
+ node = n,
+ action_type = "wikify",
+ action_date = a.wikified_at or datetime.datetime.now(),
+ extra = ''
+ )
+
+ action.save()
+
+ progress.update()
+
+ print "\n...done\n"
+
+ v_count = orm.Vote.objects.count()
+ print "\nConverting %d votes:" % v_count
+ progress = ProgressBar(v_count)
+
+ for v in orm.Vote.objects.exclude(canceled=True):
+ a = orm.Action(
+ action_type = (v.vote == 1) and ((v.node.node_type == "comment") and "voteupcomment" or "voteup") or "votedown",
+ user = v.user,
+ node = v.node,
+ action_date = v.voted_at,
+ canceled = v.canceled,
+ extra = ''
+ )
+
+ a.save()
+
+ def impl(node):
+ if node.node_type == "question":
+ return orm.Question.objects.get(node_ptr=node)
+ else:
+ return orm.Answer.objects.get(node_ptr=node)
+
+ if a.node.node_type in ("question", "answer") and (not a.node.wiki or impl(a.node).wikified_at > a.action_date):
+ reptype, default = (v.vote == 1) and (GAIN_BY_UPVOTED, 10) or (LOST_BY_DOWNVOTED, 2)
+ rep = orm.ActionRepute(
+ action = a,
+ user = a.node.author,
+ value = repval_at(reptype, a.action_date, default) or default
+ )
+ rep.save()
+
+ if v.vote == -1:
+ rep = orm.ActionRepute(
+ action = a,
+ user = a.node.author,
+ value = repval_at(LOST_BY_DOWNVOTING, a.action_date, 1) or default
+ )
+ rep.save()
+
+ progress.update()
+
+ print "\n...done\n"
+
+ f_count = orm.FlaggedItem.objects.count()
+ print "\nConverting %d flags:" % f_count
+ progress = ProgressBar(f_count)
+
+ for f in orm.FlaggedItem.objects.all():
+ a = orm.Action(
+ action_type = "flag",
+ user = f.user,
+ node = f.node,
+ action_date = f.flagged_at,
+ extra = f.reason or ''
+ )
+
+ a.save()
+
+ rep = orm.ActionRepute(
+ action = a,
+ user = a.node.author,
+ value = repval_at(LOST_BY_FLAGGED, a.action_date, 2) or 2
+ )
+ rep.save()
+
+ progress.update()
+
+ print "\n...done\n"
+
+ n_count = orm.Node.objects.all().count()
+ print "\nChecking flag count of %d nodes:" % n_count
+ progress = ProgressBar(n_count)
+
+ for n in orm.Node.objects.all():
+ flags = list(orm.Action.objects.filter(action_type="flag", node=n, canceled=False).order_by('-action_date'))
+
+ if len(flags) >= 3:
+ a = flags[2]
+ rep = orm.ActionRepute(
+ action = a,
+ user = n.author,
+ value = repval_at(LOST_BY_FLAGGED_3_TIMES, a.action_date, 30)
+ )
+ rep.save()
+
+
+ if len(flags) >= 5:
+ a = flags[4]
+ rep = orm.ActionRepute(
+ action = a,
+ user = n.author,
+ value = repval_at(LOST_BY_FLAGGED_5_TIMES, a.action_date, 100)
+ )
+ rep.save()
+
+ progress.update()
+
+ print "\n...done\n"
+
+ c_count = orm.Node.objects.filter(node_type="comment").count()
+ print "\nCreating %d comment actions:" % c_count
+ progress = ProgressBar(c_count)
+
+ for c in orm.Node.objects.filter(node_type="comment").all():
+ a = orm.Action(
+ action_type = "comment",
+ user = c.author,
+ node = c,
+ action_date = c.added_at,
+ extra = ''
+ )
+
+ a.save()
+
+ if c.deleted:
+ action = orm.Action(
+ user = c.deleted_by,
+ node = c,
+ action_type = "delete",
+ action_date = c.deleted_at or datetime.datetime.now(),
+ extra = ''
+ )
+
+ action.save()
+
+ progress.update()
+
+ print "\n...done\n"
+
+
+ r_count = orm.NodeRevision.objects.exclude(revision=1).count()
+ print "\nCreating %d edit actions:" % r_count
+ progress = ProgressBar(r_count)
+
+ for r in orm.NodeRevision.objects.exclude(revision=1):
+ a = orm.Action(
+ action_type = "revise",
+ user = r.author,
+ node = r.node,
+ action_date = r.revised_at,
+ extra = r.revision
+ )
+
+ a.save()
+ progress.update()
+
+ print "\n...done\n"
+
+ u_count = orm.User.objects.all().count()
+ print "\nCreating %d user join actions and reputation recalculation:" % u_count
+ progress = ProgressBar(u_count)
+
+ for u in orm.User.objects.all():
+ a = orm.Action(
+ user = u,
+ action_date = u.date_joined,
+ action_type = "userjoins",
+ )
+
+ a.save()
+
+ rep = orm.ActionRepute(
+ action = a,
+ user = u,
+ value = 1
+ )
+ rep.save()
+
+ new_rep = orm.ActionRepute.objects.filter(user=u).aggregate(reputation=models.Sum('value'))['reputation']
+
+ if new_rep < 0:
+ new_rep = 1
+
+ u.reputation = new_rep
+ u.save()
+
+ progress.update()
+
+ print "\n...done\n"
+
+
+
+ def backwards(self, orm):
+ "Write your backwards methods here."
+
+ 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']", 'blank': 'True'})
+ },
+ 'auth.permission': {
+ 'Meta': {'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']", 'blank': 'True'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ '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']", 'blank': 'True'}),
+ 'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+ },
+ 'contenttypes.contenttype': {
+ 'Meta': {'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'})
+ },
+ 'forum.action': {
+ 'Meta': {'object_name': 'Action'},
+ 'action_date': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'action_type': ('django.db.models.fields.CharField', [], {'max_length': '16'}),
+ 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'canceled_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True'}),
+ 'canceled_by': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'canceled_actions'", 'null': 'True', 'to': "orm['forum.User']"}),
+ 'extra': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'ip': ('django.db.models.fields.CharField', [], {'max_length': '16'}),
+ 'node': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True'}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'actions'", 'to': "orm['forum.User']"})
+ },
+ 'forum.actionrepute': {
+ 'Meta': {'object_name': 'ActionRepute'},
+ 'action': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'reputes'", 'to': "orm['forum.Action']"}),
+ 'by_canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"}),
+ 'value': ('django.db.models.fields.IntegerField', [], {'default': '0'})
+ },
+ 'forum.activity': {
+ 'Meta': {'object_name': 'Activity', 'db_table': "u'activity'"},
+ 'active_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'activity_type': ('django.db.models.fields.SmallIntegerField', [], {}),
+ 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'is_auditted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'object_id': ('django.db.models.fields.PositiveIntegerField', [], {}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"})
+ },
+ 'forum.anonymousnode': {
+ 'Meta': {'object_name': 'AnonymousNode', '_ormbases': ['forum.Node']},
+ 'convertible_to': ('django.db.models.fields.CharField', [], {'default': "'node'", 'max_length': '16'}),
+ 'node_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['forum.Node']", 'unique': 'True', 'primary_key': 'True'}),
+ 'validation_hash': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'anonymous_content'", 'to': "orm['forum.Node']"})
+ },
+ 'forum.answer': {
+ 'Meta': {'object_name': 'Answer', 'db_table': "u'answer'"},
+ 'accepted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'accepted_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
+ 'accepted_by': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']", 'null': 'True'}),
+ 'node_ptr': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True', 'primary_key': 'True'}),
+ 'wiki': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'wikified_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'})
+ },
+ 'forum.authkeyuserassociation': {
+ 'Meta': {'object_name': 'AuthKeyUserAssociation'},
+ 'added_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
+ 'provider': ('django.db.models.fields.CharField', [], {'max_length': '64'}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'auth_keys'", 'to': "orm['forum.User']"})
+ },
+ 'forum.award': {
+ 'Meta': {'object_name': 'Award', 'db_table': "u'award'"},
+ 'awarded_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'badge': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'award_badge'", 'to': "orm['forum.Badge']"}),
+ 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'notified': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'object_id': ('django.db.models.fields.PositiveIntegerField', [], {}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'awards'", 'to': "orm['forum.User']"})
+ },
+ 'forum.badge': {
+ 'Meta': {'unique_together': "(('name', 'type'),)", 'object_name': 'Badge', 'db_table': "u'badge'"},
+ 'awarded_count': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
+ 'awarded_to': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'badges'", 'through': "'Award'", 'to': "orm['forum.User']"}),
+ 'description': ('django.db.models.fields.CharField', [], {'max_length': '300'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'multiple': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
+ 'slug': ('django.db.models.fields.SlugField', [], {'db_index': 'True', 'max_length': '50', 'blank': 'True'}),
+ 'type': ('django.db.models.fields.SmallIntegerField', [], {})
+ },
+ 'forum.favoritequestion': {
+ 'Meta': {'unique_together': "(('question', 'user'),)", 'object_name': 'FavoriteQuestion', 'db_table': "u'favorite_question'"},
+ 'added_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'question': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'favourites'", 'to': "orm['forum.Question']"}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'user_favorite_questions'", 'to': "orm['forum.User']"})
+ },
+ 'forum.flaggeditem': {
+ 'Meta': {'object_name': 'FlaggedItem', 'db_table': "u'flagged_item'"},
+ 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'flagged_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'flaggeditems'", 'null': 'True', 'to': "orm['forum.Node']"}),
+ 'reason': ('django.db.models.fields.CharField', [], {'max_length': '300', 'null': 'True'}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'flaggeditems'", 'to': "orm['forum.User']"})
+ },
+ 'forum.keyvalue': {
+ 'Meta': {'object_name': 'KeyValue'},
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
+ 'value': ('forum.models.utils.PickledObjectField', [], {})
+ },
+ 'forum.markedtag': {
+ 'Meta': {'object_name': 'MarkedTag'},
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'reason': ('django.db.models.fields.CharField', [], {'max_length': '16'}),
+ 'tag': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'user_selections'", 'to': "orm['forum.Tag']"}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'tag_selections'", 'to': "orm['forum.User']"})
+ },
+ 'forum.node': {
+ 'Meta': {'object_name': 'Node'},
+ 'abs_parent': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'all_children'", 'null': 'True', 'to': "orm['forum.Node']"}),
+ 'active_revision': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'active'", 'unique': 'True', 'null': 'True', 'to': "orm['forum.NodeRevision']"}),
+ 'added_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'author': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'nodes'", 'to': "orm['forum.User']"}),
+ 'body': ('django.db.models.fields.TextField', [], {}),
+ 'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'deleted_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
+ 'deleted_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'deleted_nodes'", 'null': 'True', 'to': "orm['forum.User']"}),
+ 'extra_count': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
+ 'extra_ref': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'last_activity_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
+ 'last_activity_by': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']", 'null': 'True'}),
+ 'last_edited_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
+ 'last_edited_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'last_edited_nodes'", 'null': 'True', 'to': "orm['forum.User']"}),
+ 'marked': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'node_type': ('django.db.models.fields.CharField', [], {'default': "'node'", 'max_length': '16'}),
+ 'parent': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'children'", 'null': 'True', 'to': "orm['forum.Node']"}),
+ 'score': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
+ 'tagnames': ('django.db.models.fields.CharField', [], {'max_length': '125'}),
+ 'tags': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'nodes'", 'to': "orm['forum.Tag']"}),
+ 'title': ('django.db.models.fields.CharField', [], {'max_length': '300'}),
+ 'wiki': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'})
+ },
+ 'forum.noderevision': {
+ 'Meta': {'unique_together': "(('node', 'revision'),)", 'object_name': 'NodeRevision'},
+ 'author': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'noderevisions'", 'to': "orm['forum.User']"}),
+ 'body': ('django.db.models.fields.TextField', [], {}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'revisions'", 'to': "orm['forum.Node']"}),
+ 'revised_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'revision': ('django.db.models.fields.PositiveIntegerField', [], {}),
+ 'summary': ('django.db.models.fields.CharField', [], {'max_length': '300'}),
+ 'tagnames': ('django.db.models.fields.CharField', [], {'max_length': '125'}),
+ 'title': ('django.db.models.fields.CharField', [], {'max_length': '300'})
+ },
+ 'forum.openidassociation': {
+ 'Meta': {'object_name': 'OpenIdAssociation'},
+ 'assoc_type': ('django.db.models.fields.TextField', [], {'max_length': '64'}),
+ 'handle': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'issued': ('django.db.models.fields.IntegerField', [], {}),
+ 'lifetime': ('django.db.models.fields.IntegerField', [], {}),
+ 'secret': ('django.db.models.fields.TextField', [], {'max_length': '255'}),
+ 'server_url': ('django.db.models.fields.TextField', [], {'max_length': '2047'})
+ },
+ 'forum.openidnonce': {
+ 'Meta': {'object_name': 'OpenIdNonce'},
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'salt': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
+ 'server_url': ('django.db.models.fields.URLField', [], {'max_length': '200'}),
+ 'timestamp': ('django.db.models.fields.IntegerField', [], {})
+ },
+ 'forum.question': {
+ 'Meta': {'object_name': 'Question', 'db_table': "u'question'"},
+ 'accepted_answer': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'question_accepting'", 'unique': 'True', 'null': 'True', 'to': "orm['forum.Answer']"}),
+ 'close_reason': ('django.db.models.fields.SmallIntegerField', [], {'null': 'True', 'blank': 'True'}),
+ 'closed': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'closed_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
+ 'closed_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'closed_questions'", 'null': 'True', 'to': "orm['forum.User']"}),
+ 'favorited_by': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'favorite_questions'", 'through': "'FavoriteQuestion'", 'to': "orm['forum.User']"}),
+ 'last_activity_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'last_activity_by': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'last_active_in_questions'", 'null': 'True', 'to': "orm['forum.User']"}),
+ 'node_ptr': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']", 'null': 'True', 'primary_key': 'True'}),
+ 'view_count': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
+ 'wiki': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'wikified_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'})
+ },
+ 'forum.questionsubscription': {
+ 'Meta': {'object_name': 'QuestionSubscription'},
+ 'auto_subscription': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'last_view': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2010, 4, 27, 11, 40, 32, 68000)'}),
+ 'question': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Node']"}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"})
+ },
+ 'forum.repute': {
+ 'Meta': {'object_name': 'Repute', 'db_table': "u'repute'"},
+ 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'reputes'", 'null': 'True', 'to': "orm['forum.Node']"}),
+ 'question': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.Question']"}),
+ 'reputation_type': ('django.db.models.fields.SmallIntegerField', [], {}),
+ 'reputed_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'reputes'", 'to': "orm['forum.User']"}),
+ 'user_previous_rep': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
+ 'value': ('django.db.models.fields.SmallIntegerField', [], {'default': '0'})
+ },
+ 'forum.subscriptionsettings': {
+ 'Meta': {'object_name': 'SubscriptionSettings'},
+ 'all_questions': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'all_questions_watched_tags': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'enable_notifications': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'member_joins': ('django.db.models.fields.CharField', [], {'default': "'n'", 'max_length': '1'}),
+ 'new_question': ('django.db.models.fields.CharField', [], {'default': "'d'", 'max_length': '1'}),
+ 'new_question_watched_tags': ('django.db.models.fields.CharField', [], {'default': "'i'", 'max_length': '1'}),
+ 'notify_accepted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'notify_answers': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'notify_comments': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'notify_comments_own_post': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'notify_reply_to_comments': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'questions_answered': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'questions_asked': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
+ 'questions_commented': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'questions_viewed': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'subscribed_questions': ('django.db.models.fields.CharField', [], {'default': "'i'", 'max_length': '1'}),
+ 'user': ('django.db.models.fields.related.OneToOneField', [], {'related_name': "'subscription_settings'", 'unique': 'True', 'to': "orm['forum.User']"})
+ },
+ 'forum.tag': {
+ 'Meta': {'object_name': 'Tag', 'db_table': "u'tag'"},
+ 'created_by': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'created_tags'", 'to': "orm['forum.User']"}),
+ 'deleted': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'deleted_at': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
+ 'deleted_by': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'deleted_tags'", 'null': 'True', 'to': "orm['forum.User']"}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'marked_by': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'marked_tags'", 'through': "'MarkedTag'", 'to': "orm['forum.User']"}),
+ 'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
+ 'used_count': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'})
+ },
+ 'forum.user': {
+ 'Meta': {'object_name': 'User', '_ormbases': ['auth.User']},
+ 'about': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+ 'bronze': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
+ 'date_of_birth': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+ 'email_isvalid': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'email_key': ('django.db.models.fields.CharField', [], {'max_length': '32', 'null': 'True'}),
+ 'gold': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
+ 'hide_ignored_questions': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'is_approved': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'last_seen': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'location': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
+ 'questions_per_page': ('django.db.models.fields.SmallIntegerField', [], {'default': '10'}),
+ 'real_name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
+ 'reputation': ('django.db.models.fields.PositiveIntegerField', [], {'default': '1'}),
+ 'silver': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
+ 'subscriptions': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'subscribers'", 'through': "'QuestionSubscription'", 'to': "orm['forum.Node']"}),
+ 'user_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True', 'primary_key': 'True'}),
+ 'website': ('django.db.models.fields.URLField', [], {'max_length': '200', 'blank': 'True'})
+ },
+ 'forum.validationhash': {
+ 'Meta': {'unique_together': "(('user', 'type'),)", 'object_name': 'ValidationHash'},
+ 'expiration': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2010, 4, 28, 11, 40, 32, 153000)'}),
+ 'hash_code': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'seed': ('django.db.models.fields.CharField', [], {'max_length': '12'}),
+ 'type': ('django.db.models.fields.CharField', [], {'max_length': '12'}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['forum.User']"})
+ },
+ 'forum.vote': {
+ 'Meta': {'object_name': 'Vote', 'db_table': "u'vote'"},
+ 'canceled': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
+ 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'node': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'votes'", 'null': 'True', 'to': "orm['forum.Node']"}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'votes'", 'to': "orm['forum.User']"}),
+ 'vote': ('django.db.models.fields.SmallIntegerField', [], {}),
+ 'voted_at': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'})
+ }
+ }
+
+ complete_apps = ['forum']