Browse Source

Make order number unique

Oscar creates unique order numbers by default (and so should you!). But
it wasn't set as such in the field decleration, which is now remedied.

Reported in #1194. Thanks!

Fixes #1194.
master
Maik Hoepfel 11 years ago
parent
commit
019e9c7abb

+ 5
- 0
docs/source/releases/v0.8.rst View File

@@ -292,6 +292,10 @@ Misc
292 292
   your total scores will be change. If you rely on the old behaviour,
293 293
   just extend the ``Calculator`` class and adjust the weights.
294 294
 
295
+* ``Order.order_number`` now has ``unique=True`` set. If order numbers are
296
+  not unique in your database, you need to remedy that before migrating. By
297
+  default, Oscar creates unique order numbers.
298
+
295 299
 * ``Product.score`` was just duplicating ``ProductRecord.score`` and has been
296 300
   removed. Use ``Product.stats.score`` instead.
297 301
 
@@ -381,6 +385,7 @@ Migrations
381 385
 * Order:
382 386
 
383 387
     - ``0029`` - Add ``unique_together`` to ``PaymentEventQuantity`` and ``ShippingEventQuantity``
388
+    - ``0030`` - Set ``unique=True`` for ``Order.order_number``
384 389
 
385 390
 * Promotions:
386 391
 

+ 5
- 3
oscar/apps/order/abstract_models.py View File

@@ -18,11 +18,13 @@ class AbstractOrder(models.Model):
18 18
     """
19 19
     The main order model
20 20
     """
21
-    number = models.CharField(_("Order number"), max_length=128, db_index=True)
21
+    number = models.CharField(
22
+        _("Order number"), max_length=128, db_index=True, unique=True)
22 23
 
23 24
     # We track the site that each order is placed within
24
-    site = models.ForeignKey('sites.Site', verbose_name=_("Site"), null=True,
25
-                             on_delete=models.SET_NULL)
25
+    site = models.ForeignKey(
26
+        'sites.Site', verbose_name=_("Site"), null=True,
27
+        on_delete=models.SET_NULL)
26 28
 
27 29
     basket = models.ForeignKey(
28 30
         'basket.Basket', verbose_name=_("Basket"),

+ 481
- 0
oscar/apps/order/migrations/0030_auto__add_unique_order_number.py View File

@@ -0,0 +1,481 @@
1
+# -*- coding: utf-8 -*-
2
+from south.utils import datetime_utils as datetime
3
+from south.db import db
4
+from south.v2 import SchemaMigration
5
+from django.db import models
6
+
7
+from oscar.core.compat import AUTH_USER_MODEL, AUTH_USER_MODEL_NAME
8
+
9
+
10
+class Migration(SchemaMigration):
11
+
12
+    def forwards(self, orm):
13
+        # Adding unique constraint on 'Order', fields ['number']
14
+        db.create_unique(u'order_order', ['number'])
15
+
16
+
17
+    def backwards(self, orm):
18
+        # Removing unique constraint on 'Order', fields ['number']
19
+        db.delete_unique(u'order_order', ['number'])
20
+
21
+
22
+    models = {
23
+        u'address.country': {
24
+            'Meta': {'ordering': "('-display_order', 'name')", 'object_name': 'Country'},
25
+            'display_order': ('django.db.models.fields.PositiveSmallIntegerField', [], {'default': '0', 'db_index': 'True'}),
26
+            'is_shipping_country': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_index': 'True'}),
27
+            'iso_3166_1_a2': ('django.db.models.fields.CharField', [], {'max_length': '2', 'primary_key': 'True'}),
28
+            'iso_3166_1_a3': ('django.db.models.fields.CharField', [], {'db_index': 'True', 'max_length': '3', 'blank': 'True'}),
29
+            'iso_3166_1_numeric': ('django.db.models.fields.PositiveSmallIntegerField', [], {'null': 'True', 'db_index': 'True'}),
30
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
31
+            'printable_name': ('django.db.models.fields.CharField', [], {'max_length': '128'})
32
+        },
33
+        u'auth.group': {
34
+            'Meta': {'object_name': 'Group'},
35
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
36
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
37
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
38
+        },
39
+        u'auth.permission': {
40
+            'Meta': {'ordering': "(u'content_type__app_label', u'content_type__model', u'codename')", 'unique_together': "((u'content_type', u'codename'),)", 'object_name': 'Permission'},
41
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
42
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['contenttypes.ContentType']"}),
43
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
44
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
45
+        },
46
+        AUTH_USER_MODEL: {
47
+            'Meta': {'object_name': AUTH_USER_MODEL_NAME},
48
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
49
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
50
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
51
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
52
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
53
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
54
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
55
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
56
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
57
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
58
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
59
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
60
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
61
+        },
62
+        u'basket.basket': {
63
+            'Meta': {'object_name': 'Basket'},
64
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
65
+            'date_merged': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
66
+            'date_submitted': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
67
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
68
+            'owner': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'baskets'", 'null': 'True', 'to': u"orm['{0}']".format(AUTH_USER_MODEL)}),
69
+            'status': ('django.db.models.fields.CharField', [], {'default': "'Open'", 'max_length': '128'}),
70
+            'vouchers': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': u"orm['voucher.Voucher']", 'null': 'True', 'blank': 'True'})
71
+        },
72
+        u'catalogue.attributeentity': {
73
+            'Meta': {'object_name': 'AttributeEntity'},
74
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
75
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
76
+            'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'blank': 'True'}),
77
+            'type': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'entities'", 'to': u"orm['catalogue.AttributeEntityType']"})
78
+        },
79
+        u'catalogue.attributeentitytype': {
80
+            'Meta': {'object_name': 'AttributeEntityType'},
81
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
82
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
83
+            'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'blank': 'True'})
84
+        },
85
+        u'catalogue.attributeoption': {
86
+            'Meta': {'object_name': 'AttributeOption'},
87
+            'group': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'options'", 'to': u"orm['catalogue.AttributeOptionGroup']"}),
88
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
89
+            'option': ('django.db.models.fields.CharField', [], {'max_length': '255'})
90
+        },
91
+        u'catalogue.attributeoptiongroup': {
92
+            'Meta': {'object_name': 'AttributeOptionGroup'},
93
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
94
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'})
95
+        },
96
+        u'catalogue.category': {
97
+            'Meta': {'ordering': "['full_name']", 'object_name': 'Category'},
98
+            'depth': ('django.db.models.fields.PositiveIntegerField', [], {}),
99
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
100
+            'full_name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'db_index': 'True'}),
101
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
102
+            'image': ('django.db.models.fields.files.ImageField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
103
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'db_index': 'True'}),
104
+            'numchild': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
105
+            'path': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
106
+            'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255'})
107
+        },
108
+        u'catalogue.option': {
109
+            'Meta': {'object_name': 'Option'},
110
+            'code': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
111
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
112
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
113
+            'type': ('django.db.models.fields.CharField', [], {'default': "'Required'", 'max_length': '128'})
114
+        },
115
+        u'catalogue.product': {
116
+            'Meta': {'ordering': "['-date_created']", 'object_name': 'Product'},
117
+            'attributes': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.ProductAttribute']", 'through': u"orm['catalogue.ProductAttributeValue']", 'symmetrical': 'False'}),
118
+            'categories': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Category']", 'through': u"orm['catalogue.ProductCategory']", 'symmetrical': 'False'}),
119
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
120
+            'date_updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'db_index': 'True', 'blank': 'True'}),
121
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
122
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
123
+            'is_discountable': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
124
+            'parent': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'variants'", 'null': 'True', 'to': u"orm['catalogue.Product']"}),
125
+            'product_class': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'products'", 'null': 'True', 'on_delete': 'models.PROTECT', 'to': u"orm['catalogue.ProductClass']"}),
126
+            'product_options': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Option']", 'symmetrical': 'False', 'blank': 'True'}),
127
+            'rating': ('django.db.models.fields.FloatField', [], {'null': 'True'}),
128
+            'recommended_products': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Product']", 'symmetrical': 'False', 'through': u"orm['catalogue.ProductRecommendation']", 'blank': 'True'}),
129
+            'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255'}),
130
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
131
+            'upc': ('oscar.models.fields.NullCharField', [], {'max_length': '64', 'unique': 'True', 'null': 'True', 'blank': 'True'})
132
+        },
133
+        u'catalogue.productattribute': {
134
+            'Meta': {'ordering': "['code']", 'object_name': 'ProductAttribute'},
135
+            'code': ('django.db.models.fields.SlugField', [], {'max_length': '128'}),
136
+            'entity_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeEntityType']", 'null': 'True', 'blank': 'True'}),
137
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
138
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
139
+            'option_group': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeOptionGroup']", 'null': 'True', 'blank': 'True'}),
140
+            'product_class': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'attributes'", 'null': 'True', 'to': u"orm['catalogue.ProductClass']"}),
141
+            'required': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
142
+            'type': ('django.db.models.fields.CharField', [], {'default': "'text'", 'max_length': '20'})
143
+        },
144
+        u'catalogue.productattributevalue': {
145
+            'Meta': {'unique_together': "(('attribute', 'product'),)", 'object_name': 'ProductAttributeValue'},
146
+            'attribute': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.ProductAttribute']"}),
147
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
148
+            'product': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'attribute_values'", 'to': u"orm['catalogue.Product']"}),
149
+            'value_boolean': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}),
150
+            'value_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
151
+            'value_entity': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeEntity']", 'null': 'True', 'blank': 'True'}),
152
+            'value_file': ('django.db.models.fields.files.FileField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
153
+            'value_float': ('django.db.models.fields.FloatField', [], {'null': 'True', 'blank': 'True'}),
154
+            'value_image': ('django.db.models.fields.files.ImageField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
155
+            'value_integer': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
156
+            'value_option': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeOption']", 'null': 'True', 'blank': 'True'}),
157
+            'value_richtext': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
158
+            'value_text': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'})
159
+        },
160
+        u'catalogue.productcategory': {
161
+            'Meta': {'ordering': "['product', 'category']", 'unique_together': "(('product', 'category'),)", 'object_name': 'ProductCategory'},
162
+            'category': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Category']"}),
163
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
164
+            'product': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']"})
165
+        },
166
+        u'catalogue.productclass': {
167
+            'Meta': {'ordering': "['name']", 'object_name': 'ProductClass'},
168
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
169
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
170
+            'options': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Option']", 'symmetrical': 'False', 'blank': 'True'}),
171
+            'requires_shipping': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
172
+            'slug': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
173
+            'track_stock': ('django.db.models.fields.BooleanField', [], {'default': 'True'})
174
+        },
175
+        u'catalogue.productrecommendation': {
176
+            'Meta': {'ordering': "['primary', '-ranking']", 'unique_together': "(('primary', 'recommendation'),)", 'object_name': 'ProductRecommendation'},
177
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
178
+            'primary': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'primary_recommendations'", 'to': u"orm['catalogue.Product']"}),
179
+            'ranking': ('django.db.models.fields.PositiveSmallIntegerField', [], {'default': '0'}),
180
+            'recommendation': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']"})
181
+        },
182
+        u'contenttypes.contenttype': {
183
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
184
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
185
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
186
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
187
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
188
+        },
189
+        u'customer.communicationeventtype': {
190
+            'Meta': {'object_name': 'CommunicationEventType'},
191
+            'category': ('django.db.models.fields.CharField', [], {'default': "u'Order related'", 'max_length': '255'}),
192
+            'code': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'_'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
193
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
194
+            'date_updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
195
+            'email_body_html_template': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
196
+            'email_body_template': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
197
+            'email_subject_template': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
198
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
199
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
200
+            'sms_template': ('django.db.models.fields.CharField', [], {'max_length': '170', 'null': 'True', 'blank': 'True'})
201
+        },
202
+        u'offer.benefit': {
203
+            'Meta': {'object_name': 'Benefit'},
204
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
205
+            'max_affected_items': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
206
+            'proxy_class': ('oscar.models.fields.NullCharField', [], {'default': 'None', 'max_length': '255', 'unique': 'True', 'null': 'True', 'blank': 'True'}),
207
+            'range': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['offer.Range']", 'null': 'True', 'blank': 'True'}),
208
+            'type': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
209
+            'value': ('oscar.models.fields.PositiveDecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'})
210
+        },
211
+        u'offer.condition': {
212
+            'Meta': {'object_name': 'Condition'},
213
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
214
+            'proxy_class': ('oscar.models.fields.NullCharField', [], {'default': 'None', 'max_length': '255', 'unique': 'True', 'null': 'True', 'blank': 'True'}),
215
+            'range': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['offer.Range']", 'null': 'True', 'blank': 'True'}),
216
+            'type': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
217
+            'value': ('oscar.models.fields.PositiveDecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'})
218
+        },
219
+        u'offer.conditionaloffer': {
220
+            'Meta': {'ordering': "['-priority']", 'object_name': 'ConditionalOffer'},
221
+            'benefit': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['offer.Benefit']"}),
222
+            'condition': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['offer.Condition']"}),
223
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
224
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
225
+            'end_datetime': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
226
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
227
+            'max_basket_applications': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
228
+            'max_discount': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
229
+            'max_global_applications': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
230
+            'max_user_applications': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
231
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128'}),
232
+            'num_applications': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
233
+            'num_orders': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
234
+            'offer_type': ('django.db.models.fields.CharField', [], {'default': "'Site'", 'max_length': '128'}),
235
+            'priority': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
236
+            'redirect_url': ('oscar.models.fields.ExtendedURLField', [], {'max_length': '200', 'blank': 'True'}),
237
+            'slug': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
238
+            'start_datetime': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
239
+            'status': ('django.db.models.fields.CharField', [], {'default': "'Open'", 'max_length': '64'}),
240
+            'total_discount': ('django.db.models.fields.DecimalField', [], {'default': "'0.00'", 'max_digits': '12', 'decimal_places': '2'})
241
+        },
242
+        u'offer.range': {
243
+            'Meta': {'object_name': 'Range'},
244
+            'classes': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'classes'", 'blank': 'True', 'to': u"orm['catalogue.ProductClass']"}),
245
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
246
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
247
+            'excluded_products': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'excludes'", 'blank': 'True', 'to': u"orm['catalogue.Product']"}),
248
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
249
+            'included_categories': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'includes'", 'blank': 'True', 'to': u"orm['catalogue.Category']"}),
250
+            'included_products': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'includes'", 'blank': 'True', 'through': u"orm['offer.RangeProduct']", 'to': u"orm['catalogue.Product']"}),
251
+            'includes_all_products': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
252
+            'is_public': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
253
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128'}),
254
+            'proxy_class': ('oscar.models.fields.NullCharField', [], {'default': 'None', 'max_length': '255', 'unique': 'True', 'null': 'True', 'blank': 'True'}),
255
+            'slug': ('django.db.models.fields.SlugField', [], {'max_length': '128', 'unique': 'True', 'null': 'True'})
256
+        },
257
+        u'offer.rangeproduct': {
258
+            'Meta': {'unique_together': "(('range', 'product'),)", 'object_name': 'RangeProduct'},
259
+            'display_order': ('django.db.models.fields.IntegerField', [], {'default': '0'}),
260
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
261
+            'product': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']"}),
262
+            'range': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['offer.Range']"})
263
+        },
264
+        u'order.billingaddress': {
265
+            'Meta': {'object_name': 'BillingAddress'},
266
+            'country': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['address.Country']"}),
267
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
268
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
269
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
270
+            'line1': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
271
+            'line2': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
272
+            'line3': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
273
+            'line4': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
274
+            'postcode': ('oscar.models.fields.UppercaseCharField', [], {'max_length': '64', 'blank': 'True'}),
275
+            'search_text': ('django.db.models.fields.CharField', [], {'max_length': '1000'}),
276
+            'state': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
277
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
278
+        },
279
+        u'order.communicationevent': {
280
+            'Meta': {'ordering': "['-date_created']", 'object_name': 'CommunicationEvent'},
281
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
282
+            'event_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['customer.CommunicationEventType']"}),
283
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
284
+            'order': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'communication_events'", 'to': u"orm['order.Order']"})
285
+        },
286
+        u'order.line': {
287
+            'Meta': {'object_name': 'Line'},
288
+            'est_dispatch_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
289
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
290
+            'line_price_before_discounts_excl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
291
+            'line_price_before_discounts_incl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
292
+            'line_price_excl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
293
+            'line_price_incl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
294
+            'order': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'lines'", 'to': u"orm['order.Order']"}),
295
+            'partner': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'order_lines'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': u"orm['partner.Partner']"}),
296
+            'partner_line_notes': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
297
+            'partner_line_reference': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
298
+            'partner_name': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
299
+            'partner_sku': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
300
+            'product': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']", 'null': 'True', 'on_delete': 'models.SET_NULL', 'blank': 'True'}),
301
+            'quantity': ('django.db.models.fields.PositiveIntegerField', [], {'default': '1'}),
302
+            'status': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
303
+            'stockrecord': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['partner.StockRecord']", 'null': 'True', 'on_delete': 'models.SET_NULL', 'blank': 'True'}),
304
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
305
+            'unit_cost_price': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
306
+            'unit_price_excl_tax': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
307
+            'unit_price_incl_tax': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
308
+            'unit_retail_price': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
309
+            'upc': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'blank': 'True'})
310
+        },
311
+        u'order.lineattribute': {
312
+            'Meta': {'object_name': 'LineAttribute'},
313
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
314
+            'line': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'attributes'", 'to': u"orm['order.Line']"}),
315
+            'option': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'line_attributes'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': u"orm['catalogue.Option']"}),
316
+            'type': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
317
+            'value': ('django.db.models.fields.CharField', [], {'max_length': '255'})
318
+        },
319
+        u'order.lineprice': {
320
+            'Meta': {'ordering': "('id',)", 'object_name': 'LinePrice'},
321
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
322
+            'line': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'prices'", 'to': u"orm['order.Line']"}),
323
+            'order': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'line_prices'", 'to': u"orm['order.Order']"}),
324
+            'price_excl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
325
+            'price_incl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
326
+            'quantity': ('django.db.models.fields.PositiveIntegerField', [], {'default': '1'}),
327
+            'shipping_excl_tax': ('django.db.models.fields.DecimalField', [], {'default': '0', 'max_digits': '12', 'decimal_places': '2'}),
328
+            'shipping_incl_tax': ('django.db.models.fields.DecimalField', [], {'default': '0', 'max_digits': '12', 'decimal_places': '2'})
329
+        },
330
+        u'order.order': {
331
+            'Meta': {'ordering': "['-date_placed']", 'object_name': 'Order'},
332
+            'basket': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['basket.Basket']", 'null': 'True', 'on_delete': 'models.SET_NULL', 'blank': 'True'}),
333
+            'billing_address': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['order.BillingAddress']", 'null': 'True', 'on_delete': 'models.SET_NULL', 'blank': 'True'}),
334
+            'currency': ('django.db.models.fields.CharField', [], {'default': "'GBP'", 'max_length': '12'}),
335
+            'date_placed': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'db_index': 'True', 'blank': 'True'}),
336
+            'guest_email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
337
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
338
+            'number': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128', 'db_index': 'True'}),
339
+            'shipping_address': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['order.ShippingAddress']", 'null': 'True', 'on_delete': 'models.SET_NULL', 'blank': 'True'}),
340
+            'shipping_code': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '128', 'blank': 'True'}),
341
+            'shipping_excl_tax': ('django.db.models.fields.DecimalField', [], {'default': '0', 'max_digits': '12', 'decimal_places': '2'}),
342
+            'shipping_incl_tax': ('django.db.models.fields.DecimalField', [], {'default': '0', 'max_digits': '12', 'decimal_places': '2'}),
343
+            'shipping_method': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
344
+            'site': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['sites.Site']", 'null': 'True', 'on_delete': 'models.SET_NULL'}),
345
+            'status': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
346
+            'total_excl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
347
+            'total_incl_tax': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
348
+            'user': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'orders'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': u"orm['{0}']".format(AUTH_USER_MODEL)})
349
+        },
350
+        u'order.orderdiscount': {
351
+            'Meta': {'object_name': 'OrderDiscount'},
352
+            'amount': ('django.db.models.fields.DecimalField', [], {'default': '0', 'max_digits': '12', 'decimal_places': '2'}),
353
+            'category': ('django.db.models.fields.CharField', [], {'default': "'Basket'", 'max_length': '64'}),
354
+            'frequency': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True'}),
355
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
356
+            'message': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
357
+            'offer_id': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
358
+            'offer_name': ('django.db.models.fields.CharField', [], {'db_index': 'True', 'max_length': '128', 'blank': 'True'}),
359
+            'order': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'discounts'", 'to': u"orm['order.Order']"}),
360
+            'voucher_code': ('django.db.models.fields.CharField', [], {'db_index': 'True', 'max_length': '128', 'blank': 'True'}),
361
+            'voucher_id': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'})
362
+        },
363
+        u'order.ordernote': {
364
+            'Meta': {'object_name': 'OrderNote'},
365
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
366
+            'date_updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
367
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
368
+            'message': ('django.db.models.fields.TextField', [], {}),
369
+            'note_type': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
370
+            'order': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'notes'", 'to': u"orm['order.Order']"}),
371
+            'user': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['{0}']".format(AUTH_USER_MODEL), 'null': 'True'})
372
+        },
373
+        u'order.paymentevent': {
374
+            'Meta': {'ordering': "['-date_created']", 'object_name': 'PaymentEvent'},
375
+            'amount': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'}),
376
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
377
+            'event_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['order.PaymentEventType']"}),
378
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
379
+            'lines': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['order.Line']", 'through': u"orm['order.PaymentEventQuantity']", 'symmetrical': 'False'}),
380
+            'order': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'payment_events'", 'to': u"orm['order.Order']"}),
381
+            'reference': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
382
+            'shipping_event': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'payment_events'", 'null': 'True', 'to': u"orm['order.ShippingEvent']"})
383
+        },
384
+        u'order.paymenteventquantity': {
385
+            'Meta': {'unique_together': "(('event', 'line'),)", 'object_name': 'PaymentEventQuantity'},
386
+            'event': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'line_quantities'", 'to': u"orm['order.PaymentEvent']"}),
387
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
388
+            'line': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'payment_event_quantities'", 'to': u"orm['order.Line']"}),
389
+            'quantity': ('django.db.models.fields.PositiveIntegerField', [], {})
390
+        },
391
+        u'order.paymenteventtype': {
392
+            'Meta': {'ordering': "('name',)", 'object_name': 'PaymentEventType'},
393
+            'code': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
394
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
395
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128'})
396
+        },
397
+        u'order.shippingaddress': {
398
+            'Meta': {'object_name': 'ShippingAddress'},
399
+            'country': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['address.Country']"}),
400
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
401
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
402
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
403
+            'line1': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
404
+            'line2': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
405
+            'line3': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
406
+            'line4': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
407
+            'notes': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
408
+            'phone_number': ('oscar.models.fields.PhoneNumberField', [], {'max_length': '128', 'blank': 'True'}),
409
+            'postcode': ('oscar.models.fields.UppercaseCharField', [], {'max_length': '64', 'blank': 'True'}),
410
+            'search_text': ('django.db.models.fields.CharField', [], {'max_length': '1000'}),
411
+            'state': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
412
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
413
+        },
414
+        u'order.shippingevent': {
415
+            'Meta': {'ordering': "['-date_created']", 'object_name': 'ShippingEvent'},
416
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
417
+            'event_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['order.ShippingEventType']"}),
418
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
419
+            'lines': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'shipping_events'", 'symmetrical': 'False', 'through': u"orm['order.ShippingEventQuantity']", 'to': u"orm['order.Line']"}),
420
+            'notes': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
421
+            'order': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'shipping_events'", 'to': u"orm['order.Order']"})
422
+        },
423
+        u'order.shippingeventquantity': {
424
+            'Meta': {'unique_together': "(('event', 'line'),)", 'object_name': 'ShippingEventQuantity'},
425
+            'event': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'line_quantities'", 'to': u"orm['order.ShippingEvent']"}),
426
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
427
+            'line': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'shipping_event_quantities'", 'to': u"orm['order.Line']"}),
428
+            'quantity': ('django.db.models.fields.PositiveIntegerField', [], {})
429
+        },
430
+        u'order.shippingeventtype': {
431
+            'Meta': {'ordering': "('name',)", 'object_name': 'ShippingEventType'},
432
+            'code': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
433
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
434
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'})
435
+        },
436
+        u'partner.partner': {
437
+            'Meta': {'object_name': 'Partner'},
438
+            'code': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
439
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
440
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '128', 'blank': 'True'}),
441
+            'users': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'partners'", 'null': 'True', 'symmetrical': 'False', 'to': u"orm['{0}']".format(AUTH_USER_MODEL)})
442
+        },
443
+        u'partner.stockrecord': {
444
+            'Meta': {'unique_together': "(('partner', 'partner_sku'),)", 'object_name': 'StockRecord'},
445
+            'cost_price': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
446
+            'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
447
+            'date_updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'db_index': 'True', 'blank': 'True'}),
448
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
449
+            'low_stock_threshold': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
450
+            'num_allocated': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
451
+            'num_in_stock': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
452
+            'partner': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'stockrecords'", 'to': u"orm['partner.Partner']"}),
453
+            'partner_sku': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
454
+            'price_currency': ('django.db.models.fields.CharField', [], {'default': "'GBP'", 'max_length': '12'}),
455
+            'price_excl_tax': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
456
+            'price_retail': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
457
+            'product': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'stockrecords'", 'to': u"orm['catalogue.Product']"})
458
+        },
459
+        u'sites.site': {
460
+            'Meta': {'ordering': "('domain',)", 'object_name': 'Site', 'db_table': "'django_site'"},
461
+            'domain': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
462
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
463
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
464
+        },
465
+        u'voucher.voucher': {
466
+            'Meta': {'object_name': 'Voucher'},
467
+            'code': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '128', 'db_index': 'True'}),
468
+            'date_created': ('django.db.models.fields.DateField', [], {'auto_now_add': 'True', 'blank': 'True'}),
469
+            'end_datetime': ('django.db.models.fields.DateTimeField', [], {}),
470
+            u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
471
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
472
+            'num_basket_additions': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
473
+            'num_orders': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
474
+            'offers': ('django.db.models.fields.related.ManyToManyField', [], {'related_name': "'vouchers'", 'symmetrical': 'False', 'to': u"orm['offer.ConditionalOffer']"}),
475
+            'start_datetime': ('django.db.models.fields.DateTimeField', [], {}),
476
+            'total_discount': ('django.db.models.fields.DecimalField', [], {'default': "'0.00'", 'max_digits': '12', 'decimal_places': '2'}),
477
+            'usage': ('django.db.models.fields.CharField', [], {'default': "'Multi-use'", 'max_length': '128'})
478
+        }
479
+    }
480
+
481
+    complete_apps = ['order']

Loading…
Cancel
Save