bbe9e70581aa11609c7b8a5340cd216ac77e7eb5
[wolnelektury.git] / apps / catalogue / migrations / 0005_many2many_files_for_books.py
1 # encoding: utf-8
2 import datetime
3 from south.db import db
4 from south.v2 import SchemaMigration
5 from django.db import models
6
7 class Migration(SchemaMigration):
8
9     def forwards(self, orm):
10         # Adding model 'BookMedia'
11         db.create_table('catalogue_bookmedia', (
12             ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
13             ('type', self.gf('django.db.models.fields.CharField')(max_length='100')),
14             ('name', self.gf('django.db.models.fields.CharField')(max_length='100')),
15             ('file', self.gf('django.db.models.fields.files.FileField')(max_length=100, blank=True)),
16             ('uploaded_at', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
17         ))
18         db.send_create_signal('catalogue', ['BookMedia'])
19         
20         # Saving data which would be 'Lost In Migration'
21         if not db.dry_run:        
22             medias = []
23             for book in orm.Book.objects.all():
24                 medias.append({"url": book.odt_file,   "book": book, "type": "odt"  })
25                 medias.append({"url": book.daisy_file, "book": book, "type": "daisy"})
26                 medias.append({"url": book.ogg_file,   "book": book, "type": "ogg"  })
27                 medias.append({"url": book.mp3_file,   "book": book, "type": "mp3"  })            
28
29         # Deleting field 'Book.odt_file'
30         db.delete_column('catalogue_book', 'odt_file')
31
32         # Deleting field 'Book.daisy_file'
33         db.delete_column('catalogue_book', 'daisy_file')
34
35         # Deleting field 'Book.ogg_file'
36         db.delete_column('catalogue_book', 'ogg_file')
37
38         # Deleting field 'Book.mp3_file'
39         db.delete_column('catalogue_book', 'mp3_file')
40
41         # Adding M2M table for field medias on 'Book'
42         db.create_table('catalogue_book_medias', (
43             ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
44             ('book', models.ForeignKey(orm['catalogue.book'], null=False)),
45             ('bookmedia', models.ForeignKey(orm['catalogue.bookmedia'], null=False))
46         ))
47         db.create_unique('catalogue_book_medias', ['book_id', 'bookmedia_id'])
48
49         # Changing field 'Tag.main_page'
50         db.alter_column('catalogue_tag', 'main_page', self.gf('django.db.models.fields.BooleanField')(blank=True))
51
52         # Moving data from previous state to the new one
53         if not db.dry_run:        
54             for media in medias:
55                 try:
56                     name = media['url'].split("/")[-1].split(".")[1]
57                 except:
58                     name = media['url'].split("/")[-1]
59                 bookMedia = orm.BookMedia.objects.create(file=media['url'], type=media['type'], name=name)
60                 media['book'].medias.add(bookMedia)
61                 
62     def backwards(self, orm):
63         
64         # Deleting model 'BookMedia'
65         db.delete_table('catalogue_bookmedia')
66
67         # Adding field 'Book.odt_file'
68         db.add_column('catalogue_book', 'odt_file', self.gf('django.db.models.fields.files.FileField')(default=None, max_length=100, blank=True), keep_default=False)
69
70         # Adding field 'Book.daisy_file'
71         db.add_column('catalogue_book', 'daisy_file', self.gf('django.db.models.fields.files.FileField')(default=None, max_length=100, blank=True), keep_default=False)
72
73         # Adding field 'Book.ogg_file'
74         db.add_column('catalogue_book', 'ogg_file', self.gf('django.db.models.fields.files.FileField')(default=None, max_length=100, blank=True), keep_default=False)
75
76         # Adding field 'Book.mp3_file'
77         db.add_column('catalogue_book', 'mp3_file', self.gf('django.db.models.fields.files.FileField')(default=None, max_length=100, blank=True), keep_default=False)
78
79         # Removing M2M table for field medias on 'Book'
80         db.delete_table('catalogue_book_medias')
81
82         # Changing field 'Tag.main_page'
83         db.alter_column('catalogue_tag', 'main_page', self.gf('django.db.models.fields.BooleanField')())
84
85
86     models = {
87         'auth.group': {
88             'Meta': {'object_name': 'Group'},
89             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
90             'name': ('django.db.models.fields.CharField', [], {'max_length': '80', 'unique': 'True'}),
91             'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
92         },
93         'auth.permission': {
94             'Meta': {'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
95             'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
96             'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
97             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
98             'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
99         },
100         'auth.user': {
101             'Meta': {'object_name': 'User'},
102             'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
103             'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
104             'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
105             'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
106             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
107             'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True', 'blank': 'True'}),
108             'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
109             'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'blank': 'True'}),
110             'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
111             'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
112             'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
113             'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
114             'username': ('django.db.models.fields.CharField', [], {'max_length': '30', 'unique': 'True'})
115         },
116         'catalogue.book': {
117             'Meta': {'object_name': 'Book'},
118             '_short_html': ('django.db.models.fields.TextField', [], {}),
119             '_short_html_de': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
120             '_short_html_en': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
121             '_short_html_es': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
122             '_short_html_fr': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
123             '_short_html_lt': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
124             '_short_html_pl': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
125             '_short_html_ru': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
126             '_short_html_uk': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
127             '_tag_counter': ('catalogue.fields.JSONField', [], {'null': 'True'}),
128             '_theme_counter': ('catalogue.fields.JSONField', [], {'null': 'True'}),
129             'created_at': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
130             'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
131             'epub_file': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'blank': 'True'}),
132             'extra_info': ('catalogue.fields.JSONField', [], {}),
133             'gazeta_link': ('django.db.models.fields.CharField', [], {'max_length': '240', 'blank': 'True'}),
134             'html_file': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'blank': 'True'}),
135             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
136             'medias': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['catalogue.BookMedia']", 'symmetrical': 'False'}),
137             'parent': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'children'", 'blank': 'True', 'null': 'True', 'to': "orm['catalogue.Book']"}),
138             'parent_number': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
139             'pdf_file': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'blank': 'True'}),
140             'slug': ('django.db.models.fields.SlugField', [], {'max_length': '120', 'unique': 'True', 'db_index': 'True'}),
141             'title': ('django.db.models.fields.CharField', [], {'max_length': '120'}),
142             'txt_file': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'blank': 'True'}),            
143             'wiki_link': ('django.db.models.fields.CharField', [], {'max_length': '240', 'blank': 'True'}),
144             'xml_file': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'blank': 'True'})
145         },
146         'catalogue.bookmedia': {
147             'Meta': {'object_name': 'BookMedia'},
148             'file': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'blank': 'True'}),
149             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
150             'name': ('django.db.models.fields.CharField', [], {'max_length': "'100'"}),
151             'type': ('django.db.models.fields.CharField', [], {'max_length': "'100'"}),
152             'uploaded_at': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'})
153         },
154         'catalogue.bookstub': {
155             'Meta': {'object_name': 'BookStub'},
156             'author': ('django.db.models.fields.CharField', [], {'max_length': '120'}),
157             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
158             'pd': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
159             'slug': ('django.db.models.fields.SlugField', [], {'max_length': '120', 'unique': 'True', 'db_index': 'True'}),
160             'title': ('django.db.models.fields.CharField', [], {'max_length': '120'}),
161             'translator': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
162             'translator_death': ('django.db.models.fields.TextField', [], {'blank': 'True'})
163         },
164         'catalogue.filerecord': {
165             'Meta': {'object_name': 'FileRecord'},
166             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
167             'sha1': ('django.db.models.fields.CharField', [], {'max_length': '40'}),
168             'slug': ('django.db.models.fields.SlugField', [], {'max_length': '120', 'db_index': 'True'}),
169             'time': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
170             'type': ('django.db.models.fields.CharField', [], {'max_length': '20', 'db_index': 'True'})
171         },
172         'catalogue.fragment': {
173             'Meta': {'object_name': 'Fragment'},
174             '_short_html': ('django.db.models.fields.TextField', [], {}),
175             '_short_html_de': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
176             '_short_html_en': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
177             '_short_html_es': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
178             '_short_html_fr': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
179             '_short_html_lt': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
180             '_short_html_pl': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
181             '_short_html_ru': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
182             '_short_html_uk': ('django.db.models.fields.TextField', [], {'null': True, 'blank': True}),
183             'anchor': ('django.db.models.fields.CharField', [], {'max_length': '120'}),
184             'book': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'fragments'", 'to': "orm['catalogue.Book']"}),
185             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
186             'short_text': ('django.db.models.fields.TextField', [], {}),
187             'text': ('django.db.models.fields.TextField', [], {})
188         },
189         'catalogue.tag': {
190             'Meta': {'unique_together': "(('slug', 'category'),)", 'object_name': 'Tag'},
191             'book_count': ('django.db.models.fields.IntegerField', [], {'null': 'True'}),
192             'category': ('django.db.models.fields.CharField', [], {'max_length': '50', 'db_index': 'True'}),
193             'death': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
194             'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
195             'gazeta_link': ('django.db.models.fields.CharField', [], {'max_length': '240', 'blank': 'True'}),
196             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
197             'main_page': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True', 'blank': 'True'}),
198             'name': ('django.db.models.fields.CharField', [], {'max_length': '50', 'db_index': 'True'}),
199             'slug': ('django.db.models.fields.SlugField', [], {'max_length': '120', 'db_index': 'True'}),
200             'sort_key': ('django.db.models.fields.SlugField', [], {'max_length': '120', 'db_index': 'True'}),
201             'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['auth.User']", 'null': 'True', 'blank': 'True'}),
202             'wiki_link': ('django.db.models.fields.CharField', [], {'max_length': '240', 'blank': 'True'})
203         },
204         'catalogue.tagrelation': {
205             'Meta': {'unique_together': "(('tag', 'content_type', 'object_id'),)", 'object_name': 'TagRelation', 'db_table': "'catalogue_tag_relation'"},
206             'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
207             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
208             'object_id': ('django.db.models.fields.PositiveIntegerField', [], {'db_index': 'True'}),
209             'tag': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'items'", 'to': "orm['catalogue.Tag']"})
210         },
211         'contenttypes.contenttype': {
212             'Meta': {'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
213             'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
214             'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
215             'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
216             'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
217         }
218     }
219
220     complete_apps = ['catalogue']