Initial philo commit to use django-taggit instead of native tags.
[philo.git] / philo / contrib / penfield / migrations / 0005_to_taggit.py
1 # encoding: utf-8
2 import datetime
3 from south.db import db
4 from south.v2 import DataMigration
5 from django.db import models
6
7 class Migration(DataMigration):
8
9         depends_on = (
10                 ("philo", "0019_to_taggit"),
11         )
12         
13         needed_by = (
14                 ("philo", "0020_from_taggit"),
15         )
16
17         def forwards(self, orm):
18                 "Write your forwards methods here."
19                 BlogEntry = orm['penfield.BlogEntry']
20                 NewsletterArticle = orm['penfield.NewsletterArticle']
21                 TaggitTag = orm['taggit.Tag']
22                 TaggedItem = orm['taggit.TaggedItem']
23                 ContentType = orm['contenttypes.contenttype']
24                 
25                 entry_ct = ContentType.objects.get(app_label="penfield", model="blogentry")
26                 article_ct = ContentType.objects.get(app_label="penfield", model="newsletterarticle")
27                 
28                 for entry in BlogEntry.objects.all():
29                         for tag in entry.tags.all():
30                                 ttag = TaggitTag.objects.get(slug=tag.slug)
31                                 TaggedItem.objects.get_or_create(tag=ttag, content_type=entry_ct, object_id=entry.pk)
32                 
33                 for article in NewsletterArticle.objects.all():
34                         for tag in article.tags.all():
35                                 ttag = TaggitTag.objects.get(slug=tag.slug)
36                                 TaggedItem.objects.get_or_create(tag=ttag, content_type=article_ct, object_id=article.pk)
37
38
39         def backwards(self, orm):
40                 "Write your backwards methods here."
41                 import pdb
42                 pdb.set_trace()
43                 BlogEntry = orm['penfield.BlogEntry']
44                 NewsletterArticle = orm['penfield.NewsletterArticle']
45                 Tag = orm['philo.Tag']
46                 TaggitTag = orm['taggit.Tag']
47                 TaggedItem = orm['taggit.TaggedItem']
48                 
49                 for entry in BlogEntry.objects.all():
50                         tag_slugs = list(TaggitTag.objects.filter(taggit_taggeditem_items__content_object=entry).values_list('slug', flat=True)).distinct()
51                         entry.tags = Tag.objects.filter(slug__in=tag_slugs)
52                         entry.save()
53                 
54                 for article in NewsletterArticle.objects.all():
55                         tag_slugs = list(TaggitTag.objects.filter(taggit_taggeditem_items__content_object=article).values_list('slug', flat=True)).distinct()
56                         article.tags = Tag.objects.filter(slug__in=tag_slugs)
57                         article.save()
58
59
60         models = {
61                 'auth.group': {
62                         'Meta': {'object_name': 'Group'},
63                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
64                         'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
65                         'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
66                 },
67                 'auth.permission': {
68                         'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
69                         'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
70                         'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
71                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
72                         'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
73                 },
74                 'auth.user': {
75                         'Meta': {'object_name': 'User'},
76                         'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
77                         'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
78                         'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
79                         'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
80                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
81                         'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
82                         'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
83                         'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
84                         'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
85                         'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
86                         'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
87                         'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
88                         'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
89                 },
90                 'contenttypes.contenttype': {
91                         'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
92                         'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
93                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
94                         'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
95                         'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
96                 },
97                 'oberlin.person': {
98                         'Meta': {'object_name': 'Person'},
99                         'bio': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
100                         'degree_type': ('django.db.models.fields.CharField', [], {'max_length': '3', 'blank': 'True'}),
101                         'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
102                         'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
103                         'graduation_year': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
104                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
105                         'name': ('django.db.models.fields.CharField', [], {'max_length': '70', 'blank': 'True'}),
106                         'phone': ('django.contrib.localflavor.us.models.PhoneNumberField', [], {'max_length': '20', 'blank': 'True'}),
107                         't_number_hash': ('django.db.models.fields.CharField', [], {'max_length': '60', 'blank': 'True'}),
108                         'user': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['auth.User']", 'unique': 'True', 'null': 'True', 'blank': 'True'})
109                 },
110                 'penfield.blog': {
111                         'Meta': {'object_name': 'Blog'},
112                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
113                         'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'db_index': 'True'}),
114                         'title': ('django.db.models.fields.CharField', [], {'max_length': '255'})
115                 },
116                 'penfield.blogentry': {
117                         'Meta': {'ordering': "['-date']", 'object_name': 'BlogEntry'},
118                         'author': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'blogentries'", 'to': "orm['oberlin.Person']"}),
119                         'blog': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'entries'", 'null': 'True', 'to': "orm['penfield.Blog']"}),
120                         'content': ('django.db.models.fields.TextField', [], {}),
121                         'date': ('django.db.models.fields.DateTimeField', [], {'default': 'None'}),
122                         'excerpt': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
123                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
124                         'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'db_index': 'True'}),
125                         'tags': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'blogentries'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['philo.Tag']"}),
126                         'title': ('django.db.models.fields.CharField', [], {'max_length': '255'})
127                 },
128                 'penfield.blogview': {
129                         'Meta': {'object_name': 'BlogView'},
130                         'blog': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'blogviews'", 'to': "orm['penfield.Blog']"}),
131                         'entries_per_page': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
132                         'entry_archive_page': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'blog_entry_archive_related'", 'null': 'True', 'to': "orm['philo.Page']"}),
133                         'entry_page': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'blog_entry_related'", 'to': "orm['philo.Page']"}),
134                         'entry_permalink_base': ('django.db.models.fields.CharField', [], {'default': "'entries'", 'max_length': '255'}),
135                         'entry_permalink_style': ('django.db.models.fields.CharField', [], {'max_length': '1'}),
136                         'feed_length': ('django.db.models.fields.PositiveIntegerField', [], {'default': '15', 'null': 'True', 'blank': 'True'}),
137                         'feed_suffix': ('django.db.models.fields.CharField', [], {'default': "'feed'", 'max_length': '255'}),
138                         'feed_type': ('django.db.models.fields.CharField', [], {'default': "'atom'", 'max_length': '50'}),
139                         'feeds_enabled': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
140                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
141                         'index_page': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'blog_index_related'", 'to': "orm['philo.Page']"}),
142                         'item_description_template': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'penfield_blogview_description_related'", 'null': 'True', 'to': "orm['philo.Template']"}),
143                         'item_title_template': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'penfield_blogview_title_related'", 'null': 'True', 'to': "orm['philo.Template']"}),
144                         'tag_archive_page': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'blog_tag_archive_related'", 'null': 'True', 'to': "orm['philo.Page']"}),
145                         'tag_page': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'blog_tag_related'", 'to': "orm['philo.Page']"}),
146                         'tag_permalink_base': ('django.db.models.fields.CharField', [], {'default': "'tags'", 'max_length': '255'})
147                 },
148                 'penfield.newsletter': {
149                         'Meta': {'object_name': 'Newsletter'},
150                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
151                         'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'db_index': 'True'}),
152                         'title': ('django.db.models.fields.CharField', [], {'max_length': '255'})
153                 },
154                 'penfield.newsletterarticle': {
155                         'Meta': {'ordering': "['-date']", 'unique_together': "(('newsletter', 'slug'),)", 'object_name': 'NewsletterArticle'},
156                         'authors': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'newsletterarticles'", 'symmetrical': 'False', 'to': "orm['oberlin.Person']"}),
157                         'date': ('django.db.models.fields.DateTimeField', [], {'default': 'None'}),
158                         'full_text': ('philo.models.fields.TemplateField', [], {'db_index': 'True'}),
159                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
160                         'lede': ('philo.models.fields.TemplateField', [], {'null': 'True', 'blank': 'True'}),
161                         'newsletter': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'articles'", 'to': "orm['penfield.Newsletter']"}),
162                         'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'db_index': 'True'}),
163                         'tags': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'newsletterarticles'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['philo.Tag']"}),
164                         'title': ('django.db.models.fields.CharField', [], {'max_length': '255'})
165                 },
166                 'penfield.newsletterissue': {
167                         'Meta': {'ordering': "['-numbering']", 'unique_together': "(('newsletter', 'numbering'),)", 'object_name': 'NewsletterIssue'},
168                         'articles': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'issues'", 'symmetrical': 'False', 'to': "orm['penfield.NewsletterArticle']"}),
169                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
170                         'newsletter': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'issues'", 'to': "orm['penfield.Newsletter']"}),
171                         'numbering': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
172                         'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'db_index': 'True'}),
173                         'title': ('django.db.models.fields.CharField', [], {'max_length': '255'})
174                 },
175                 'penfield.newsletterview': {
176                         'Meta': {'object_name': 'NewsletterView'},
177                         'article_archive_page': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'newsletter_article_archive_related'", 'null': 'True', 'to': "orm['philo.Page']"}),
178                         'article_page': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'newsletter_article_related'", 'to': "orm['philo.Page']"}),
179                         'article_permalink_base': ('django.db.models.fields.CharField', [], {'default': "'articles'", 'max_length': '255'}),
180                         'article_permalink_style': ('django.db.models.fields.CharField', [], {'max_length': '1'}),
181                         'feed_length': ('django.db.models.fields.PositiveIntegerField', [], {'default': '15', 'null': 'True', 'blank': 'True'}),
182                         'feed_suffix': ('django.db.models.fields.CharField', [], {'default': "'feed'", 'max_length': '255'}),
183                         'feed_type': ('django.db.models.fields.CharField', [], {'default': "'atom'", 'max_length': '50'}),
184                         'feeds_enabled': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
185                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
186                         'index_page': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'newsletter_index_related'", 'to': "orm['philo.Page']"}),
187                         'issue_archive_page': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'newsletter_issue_archive_related'", 'null': 'True', 'to': "orm['philo.Page']"}),
188                         'issue_page': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'newsletter_issue_related'", 'to': "orm['philo.Page']"}),
189                         'issue_permalink_base': ('django.db.models.fields.CharField', [], {'default': "'issues'", 'max_length': '255'}),
190                         'item_description_template': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'penfield_newsletterview_description_related'", 'null': 'True', 'to': "orm['philo.Template']"}),
191                         'item_title_template': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'penfield_newsletterview_title_related'", 'null': 'True', 'to': "orm['philo.Template']"}),
192                         'newsletter': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'newsletterviews'", 'to': "orm['penfield.Newsletter']"})
193                 },
194                 'philo.attribute': {
195                         'Meta': {'unique_together': "(('key', 'entity_content_type', 'entity_object_id'), ('value_content_type', 'value_object_id'))", 'object_name': 'Attribute'},
196                         'entity_content_type': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'attribute_entity_set'", 'to': "orm['contenttypes.ContentType']"}),
197                         'entity_object_id': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
198                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
199                         'key': ('django.db.models.fields.CharField', [], {'max_length': '255', 'db_index': 'True'}),
200                         'value_content_type': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'attribute_value_set'", 'null': 'True', 'to': "orm['contenttypes.ContentType']"}),
201                         'value_object_id': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True', 'null': 'True', 'blank': 'True'})
202                 },
203                 'philo.node': {
204                         'Meta': {'unique_together': "(('parent', 'slug'),)", 'object_name': 'Node'},
205                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
206                         'level': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
207                         'lft': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
208                         'parent': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'children'", 'null': 'True', 'to': "orm['philo.Node']"}),
209                         'rght': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
210                         'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'db_index': 'True'}),
211                         'tree_id': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
212                         'view_content_type': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'node_view_set'", 'null': 'True', 'to': "orm['contenttypes.ContentType']"}),
213                         'view_object_id': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'})
214                 },
215                 'philo.page': {
216                         'Meta': {'object_name': 'Page'},
217                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
218                         'template': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'pages'", 'to': "orm['philo.Template']"}),
219                         'title': ('django.db.models.fields.CharField', [], {'max_length': '255'})
220                 },
221                 'philo.tag': {
222                         'Meta': {'ordering': "('name',)", 'object_name': 'Tag'},
223                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
224                         'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
225                         'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '255', 'db_index': 'True'})
226                 },
227                 'philo.template': {
228                         'Meta': {'unique_together': "(('parent', 'slug'),)", 'object_name': 'Template'},
229                         'code': ('philo.models.fields.TemplateField', [], {}),
230                         'documentation': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
231                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
232                         'level': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
233                         'lft': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
234                         'mimetype': ('django.db.models.fields.CharField', [], {'default': "'text/html'", 'max_length': '255'}),
235                         'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
236                         'parent': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'children'", 'null': 'True', 'to': "orm['philo.Template']"}),
237                         'rght': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
238                         'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'db_index': 'True'}),
239                         'tree_id': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'})
240                 },
241                 'taggit.tag': {
242                         'Meta': {'object_name': 'Tag'},
243                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
244                         'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
245                         'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '100', 'db_index': 'True'})
246                 },
247                 'taggit.taggeditem': {
248                         'Meta': {'object_name': 'TaggedItem'},
249                         'content_type': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'taggit_taggeditem_tagged_items'", 'to': "orm['contenttypes.ContentType']"}),
250                         'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
251                         'object_id': ('django.db.models.fields.IntegerField', [], {'db_index': 'True'}),
252                         'tag': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'taggit_taggeditem_items'", 'to': "orm['taggit.Tag']"})
253                 }
254         }
255
256         complete_apps = ['penfield']