mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-10-31 07:49:57 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			210 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			210 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Generated by Django 2.2.16 on 2020-09-04 21:41
 | |
| 
 | |
| from django.conf import settings
 | |
| from django.db import migrations, models
 | |
| import django.db.models.deletion
 | |
| import django.utils.timezone
 | |
| 
 | |
| 
 | |
| class Migration(migrations.Migration):
 | |
| 
 | |
|     initial = True
 | |
| 
 | |
|     dependencies = [
 | |
|         migrations.swappable_dependency(settings.AUTH_USER_MODEL),
 | |
|         ('member', '0001_initial'),
 | |
|         ('contenttypes', '0002_remove_content_type_name'),
 | |
|     ]
 | |
| 
 | |
|     operations = [
 | |
|         migrations.CreateModel(
 | |
|             name='Note',
 | |
|             fields=[
 | |
|                 ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | |
|                 ('balance', models.BigIntegerField(default=0, help_text='in centimes, money credited for this instance', verbose_name='account balance')),
 | |
|                 ('last_negative', models.DateTimeField(blank=True, help_text='last time the balance was negative', null=True, verbose_name='last negative date')),
 | |
|                 ('display_image', models.ImageField(default='pic/default.png', max_length=255, upload_to='pic/', verbose_name='display image')),
 | |
|                 ('created_at', models.DateTimeField(default=django.utils.timezone.now, verbose_name='created at')),
 | |
|                 ('is_active', models.BooleanField(default=True, help_text='Designates whether this note should be treated as active. Unselect this instead of deleting notes.', verbose_name='active')),
 | |
|                 ('inactivity_reason', models.CharField(choices=[('manual', 'The user blocked his/her note manually, eg. when he/she left the school for holidays. It can be reactivated at any time.'), ('forced', "The note is blocked by the the BDE and can't be manually reactivated.")], default=None, max_length=255, null=True)),
 | |
|                 ('polymorphic_ctype', models.ForeignKey(editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='polymorphic_note.note_set+', to='contenttypes.ContentType')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'note',
 | |
|                 'verbose_name_plural': 'notes',
 | |
|             },
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='TemplateCategory',
 | |
|             fields=[
 | |
|                 ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | |
|                 ('name', models.CharField(max_length=31, unique=True, verbose_name='name')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'transaction category',
 | |
|                 'verbose_name_plural': 'transaction categories',
 | |
|             },
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='Transaction',
 | |
|             fields=[
 | |
|                 ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | |
|                 ('source_alias', models.CharField(default='', max_length=255, verbose_name='used alias')),
 | |
|                 ('destination_alias', models.CharField(default='', max_length=255, verbose_name='used alias')),
 | |
|                 ('created_at', models.DateTimeField(default=django.utils.timezone.now, verbose_name='created at')),
 | |
|                 ('quantity', models.PositiveIntegerField(default=1, verbose_name='quantity')),
 | |
|                 ('amount', models.PositiveIntegerField(verbose_name='amount')),
 | |
|                 ('reason', models.CharField(max_length=255, verbose_name='reason')),
 | |
|                 ('valid', models.BooleanField(default=True, verbose_name='valid')),
 | |
|                 ('invalidity_reason', models.CharField(blank=True, default=None, max_length=255, null=True, verbose_name='invalidity reason')),
 | |
|                 ('destination', models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='+', to='note.Note', verbose_name='destination')),
 | |
|                 ('polymorphic_ctype', models.ForeignKey(editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='polymorphic_note.transaction_set+', to='contenttypes.ContentType')),
 | |
|                 ('source', models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='+', to='note.Note', verbose_name='source')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'transaction',
 | |
|                 'verbose_name_plural': 'transactions',
 | |
|             },
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='MembershipTransaction',
 | |
|             fields=[
 | |
|                 ('transaction_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='note.Transaction')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'membership transaction',
 | |
|                 'verbose_name_plural': 'membership transactions',
 | |
|             },
 | |
|             bases=('note.transaction',),
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='NoteClub',
 | |
|             fields=[
 | |
|                 ('note_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='note.Note')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'club note',
 | |
|                 'verbose_name_plural': 'clubs notes',
 | |
|             },
 | |
|             bases=('note.note',),
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='NoteSpecial',
 | |
|             fields=[
 | |
|                 ('note_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='note.Note')),
 | |
|                 ('special_type', models.CharField(max_length=255, unique=True, verbose_name='type')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'special note',
 | |
|                 'verbose_name_plural': 'special notes',
 | |
|             },
 | |
|             bases=('note.note',),
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='NoteUser',
 | |
|             fields=[
 | |
|                 ('note_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='note.Note')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': "one's note",
 | |
|                 'verbose_name_plural': 'users note',
 | |
|             },
 | |
|             bases=('note.note',),
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='RecurrentTransaction',
 | |
|             fields=[
 | |
|                 ('transaction_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='note.Transaction')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'recurrent transaction',
 | |
|                 'verbose_name_plural': 'recurrent transactions',
 | |
|             },
 | |
|             bases=('note.transaction',),
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='SpecialTransaction',
 | |
|             fields=[
 | |
|                 ('transaction_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='note.Transaction')),
 | |
|                 ('last_name', models.CharField(max_length=255, verbose_name='name')),
 | |
|                 ('first_name', models.CharField(max_length=255, verbose_name='first_name')),
 | |
|                 ('bank', models.CharField(blank=True, max_length=255, verbose_name='bank')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'Special transaction',
 | |
|                 'verbose_name_plural': 'Special transactions',
 | |
|             },
 | |
|             bases=('note.transaction',),
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='Alias',
 | |
|             fields=[
 | |
|                 ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | |
|                 ('name', models.CharField(max_length=255, unique=True, verbose_name='name')),
 | |
|                 ('normalized_name', models.CharField(editable=False, max_length=255, unique=True)),
 | |
|                 ('note', models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, to='note.Note')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'alias',
 | |
|                 'verbose_name_plural': 'aliases',
 | |
|             },
 | |
|         ),
 | |
|         migrations.CreateModel(
 | |
|             name='TransactionTemplate',
 | |
|             fields=[
 | |
|                 ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | |
|                 ('name', models.CharField(error_messages={'unique': 'A template with this name already exist'}, max_length=255, unique=True, verbose_name='name')),
 | |
|                 ('amount', models.PositiveIntegerField(verbose_name='amount')),
 | |
|                 ('display', models.BooleanField(default=True, verbose_name='display')),
 | |
|                 ('highlighted', models.BooleanField(default=False, verbose_name='highlighted')),
 | |
|                 ('description', models.CharField(blank=True, max_length=255, verbose_name='description')),
 | |
|                 ('category', models.ForeignKey(max_length=31, on_delete=django.db.models.deletion.PROTECT, related_name='templates', to='note.TemplateCategory', verbose_name='type')),
 | |
|                 ('destination', models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='+', to='note.NoteClub', verbose_name='destination')),
 | |
|             ],
 | |
|             options={
 | |
|                 'verbose_name': 'transaction template',
 | |
|                 'verbose_name_plural': 'transaction templates',
 | |
|             },
 | |
|         ),
 | |
|         migrations.AddIndex(
 | |
|             model_name='transaction',
 | |
|             index=models.Index(fields=['created_at'], name='note_transa_created_bea8b1_idx'),
 | |
|         ),
 | |
|         migrations.AddIndex(
 | |
|             model_name='transaction',
 | |
|             index=models.Index(fields=['source'], name='note_transa_source__4a1a1e_idx'),
 | |
|         ),
 | |
|         migrations.AddIndex(
 | |
|             model_name='transaction',
 | |
|             index=models.Index(fields=['destination'], name='note_transa_destina_6e1bb4_idx'),
 | |
|         ),
 | |
|         migrations.AddField(
 | |
|             model_name='recurrenttransaction',
 | |
|             name='template',
 | |
|             field=models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, to='note.TransactionTemplate'),
 | |
|         ),
 | |
|         migrations.AddField(
 | |
|             model_name='noteuser',
 | |
|             name='user',
 | |
|             field=models.OneToOneField(on_delete=django.db.models.deletion.PROTECT, related_name='note', to=settings.AUTH_USER_MODEL, verbose_name='user'),
 | |
|         ),
 | |
|         migrations.AddField(
 | |
|             model_name='noteclub',
 | |
|             name='club',
 | |
|             field=models.OneToOneField(on_delete=django.db.models.deletion.PROTECT, related_name='note', to='member.Club', verbose_name='club'),
 | |
|         ),
 | |
|         migrations.AddField(
 | |
|             model_name='membershiptransaction',
 | |
|             name='membership',
 | |
|             field=models.OneToOneField(on_delete=django.db.models.deletion.PROTECT, related_name='transaction', to='member.Membership'),
 | |
|         ),
 | |
|         migrations.AddIndex(
 | |
|             model_name='alias',
 | |
|             index=models.Index(fields=['name'], name='note_alias_name_a89405_idx'),
 | |
|         ),
 | |
|         migrations.AddIndex(
 | |
|             model_name='alias',
 | |
|             index=models.Index(fields=['normalized_name'], name='note_alias_normali_bd52b4_idx'),
 | |
|         ),
 | |
|     ]
 |