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