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