/project/migrations/0005_link_invoicerow_proposal.py

https://github.com/splanquart/aemanager · Python · 160 lines · 149 code · 7 blank · 4 comment · 1 complexity · fabc5ae9d7bd3e2a72bcc97db0bdef14 MD5 · raw file

  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. class Migration(DataMigration):
  7. def forwards(self, orm):
  8. """
  9. Copy the link invoice-proposal to invoicerow-proposal
  10. """
  11. for invoice_row in orm.InvoiceRow.objects.all():
  12. proposal = invoice_row.invoice.proposal
  13. invoice_row.proposal = proposal
  14. invoice_row.save()
  15. def backwards(self, orm):
  16. pass
  17. models = {
  18. 'auth.group': {
  19. 'Meta': {'object_name': 'Group'},
  20. 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
  21. 'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
  22. 'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
  23. },
  24. 'auth.permission': {
  25. 'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
  26. 'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
  27. 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
  28. 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
  29. 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
  30. },
  31. 'auth.user': {
  32. 'Meta': {'object_name': 'User'},
  33. 'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
  34. 'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
  35. 'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
  36. 'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
  37. 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
  38. 'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
  39. 'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
  40. 'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
  41. 'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
  42. 'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
  43. 'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
  44. 'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
  45. 'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
  46. },
  47. 'contact.address': {
  48. 'Meta': {'object_name': 'Address', '_ormbases': ['core.OwnedObject']},
  49. 'city': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '255', 'blank': 'True'}),
  50. 'country': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contact.Country']", 'null': 'True', 'blank': 'True'}),
  51. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  52. 'street': ('django.db.models.fields.TextField', [], {'default': "''", 'blank': 'True'}),
  53. 'zipcode': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '10', 'blank': 'True'})
  54. },
  55. 'contact.contact': {
  56. 'Meta': {'object_name': 'Contact', '_ormbases': ['core.OwnedObject']},
  57. 'address': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contact.Address']"}),
  58. 'company_id': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '50', 'blank': 'True'}),
  59. 'contact_type': ('django.db.models.fields.IntegerField', [], {}),
  60. 'contacts': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': "orm['contact.Contact']", 'null': 'True', 'blank': 'True'}),
  61. 'email': ('django.db.models.fields.EmailField', [], {'default': "''", 'max_length': '75', 'blank': 'True'}),
  62. 'firstname': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '255', 'blank': 'True'}),
  63. 'function': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '100', 'blank': 'True'}),
  64. 'legal_form': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '255', 'blank': 'True'}),
  65. 'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
  66. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  67. 'representative': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '255', 'blank': 'True'}),
  68. 'representative_function': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '100', 'blank': 'True'})
  69. },
  70. 'contact.country': {
  71. 'Meta': {'ordering': "['country_name']", 'object_name': 'Country'},
  72. 'country_code2': ('django.db.models.fields.CharField', [], {'max_length': '2'}),
  73. 'country_code3': ('django.db.models.fields.CharField', [], {'max_length': '3'}),
  74. 'country_name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
  75. 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'})
  76. },
  77. 'contenttypes.contenttype': {
  78. 'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
  79. 'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
  80. 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
  81. 'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
  82. 'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
  83. },
  84. 'core.ownedobject': {
  85. 'Meta': {'object_name': 'OwnedObject'},
  86. 'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
  87. 'owner': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['auth.User']"})
  88. },
  89. 'project.contract': {
  90. 'Meta': {'object_name': 'Contract', '_ormbases': ['core.OwnedObject']},
  91. 'content': ('django.db.models.fields.TextField', [], {}),
  92. 'customer': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'contracts'", 'to': "orm['contact.Contact']"}),
  93. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  94. 'title': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
  95. 'update_date': ('django.db.models.fields.DateField', [], {})
  96. },
  97. 'project.invoice': {
  98. 'Meta': {'object_name': 'Invoice', '_ormbases': ['core.OwnedObject']},
  99. 'amount': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
  100. 'balance_payments': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
  101. 'customer': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contact.Contact']", 'null': 'True', 'blank': 'True'}),
  102. 'discount_conditions': ('django.db.models.fields.CharField', [], {'max_length': '100', 'null': 'True', 'blank': 'True'}),
  103. 'edition_date': ('django.db.models.fields.DateField', [], {}),
  104. 'execution_begin_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
  105. 'execution_end_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
  106. 'invoice_id': ('django.db.models.fields.IntegerField', [], {}),
  107. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  108. 'paid_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
  109. 'payment_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
  110. 'penalty_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
  111. 'penalty_rate': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '4', 'decimal_places': '2', 'blank': 'True'}),
  112. 'proposal': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'invoices'", 'to': "orm['project.Proposal']"}),
  113. 'state': ('django.db.models.fields.IntegerField', [], {'default': '1'})
  114. },
  115. 'project.invoicerow': {
  116. 'Meta': {'object_name': 'InvoiceRow'},
  117. 'category': ('django.db.models.fields.IntegerField', [], {}),
  118. 'invoice': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'invoice_rows'", 'to': "orm['project.Invoice']"}),
  119. 'label': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
  120. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  121. 'proposal': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'invoice_rows'", 'to': "orm['project.Proposal']"}),
  122. 'quantity': ('django.db.models.fields.DecimalField', [], {'max_digits': '5', 'decimal_places': '1'}),
  123. 'unit_price': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'})
  124. },
  125. 'project.project': {
  126. 'Meta': {'object_name': 'Project', '_ormbases': ['core.OwnedObject']},
  127. 'customer': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contact.Contact']", 'null': 'True', 'blank': 'True'}),
  128. 'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
  129. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  130. 'state': ('django.db.models.fields.IntegerField', [], {'default': '1'})
  131. },
  132. 'project.proposal': {
  133. 'Meta': {'object_name': 'Proposal', '_ormbases': ['core.OwnedObject']},
  134. 'amount': ('django.db.models.fields.DecimalField', [], {'null': 'True', 'max_digits': '12', 'decimal_places': '2', 'blank': 'True'}),
  135. 'begin_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
  136. 'contract_content': ('django.db.models.fields.TextField', [], {'default': "''", 'blank': 'True'}),
  137. 'end_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
  138. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  139. 'project': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['project.Project']"}),
  140. 'state': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
  141. 'update_date': ('django.db.models.fields.DateField', [], {})
  142. },
  143. 'project.proposalrow': {
  144. 'Meta': {'object_name': 'ProposalRow'},
  145. 'category': ('django.db.models.fields.IntegerField', [], {}),
  146. 'label': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
  147. 'ownedobject_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['core.OwnedObject']", 'unique': 'True', 'primary_key': 'True'}),
  148. 'proposal': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'proposal_rows'", 'to': "orm['project.Proposal']"}),
  149. 'quantity': ('django.db.models.fields.DecimalField', [], {'max_digits': '5', 'decimal_places': '1'}),
  150. 'unit_price': ('django.db.models.fields.DecimalField', [], {'max_digits': '12', 'decimal_places': '2'})
  151. }
  152. }
  153. complete_apps = ['project']