Add migration files 0001-0007 and update .gitignore

This commit is contained in:
2025-08-29 18:49:35 +09:00
parent 7593885bbc
commit 23a9902885
8 changed files with 1732 additions and 4 deletions

4
.gitignore vendored
View File

@ -157,10 +157,6 @@ dmypy.json
# Cython debug symbols # Cython debug symbols
cython_debug/ cython_debug/
# migration files
rog/migrations/
# PyCharm # PyCharm
# JetBrains specific template is maintainted in a separate JetBrains.gitignore that can # JetBrains specific template is maintainted in a separate JetBrains.gitignore that can
# be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore # be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore

View File

@ -0,0 +1,155 @@
# -*- coding: utf-8 -*-
# Generated by reset_migrations_simple.py - Simple Version
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 = [
('auth', '0012_alter_user_first_name_max_length'),
]
operations = [
# 基本的なモデルのみ作成managed=Falseのモデルは除外
# 1. ユーザー関連モデル
migrations.CreateModel(
name='CustomUser',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('password', models.CharField(max_length=128, verbose_name='password')),
('last_login', models.DateTimeField(blank=True, null=True, verbose_name='last login')),
('is_superuser', models.BooleanField(default=False, help_text='Designates that this user has all permissions without explicitly assigning them.', verbose_name='superuser status')),
('email', models.EmailField(max_length=254, unique=True)),
('firstname', models.CharField(blank=True, max_length=255, null=True)),
('lastname', models.CharField(blank=True, max_length=255, null=True)),
('date_of_birth', models.DateField(blank=True, null=True)),
('female', models.BooleanField(default=False)),
('group', models.CharField(blank=True, max_length=255)),
('is_active', models.BooleanField(default=True)),
('is_staff', models.BooleanField(default=False)),
('date_joined', models.DateTimeField(default=django.utils.timezone.now)),
('is_rogaining', models.BooleanField(default=False)),
('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.Group', verbose_name='groups')),
('user_permissions', models.ManyToManyField(blank=True, help_text='Specific permissions for this user.', related_name='user_set', related_query_name='user', to='auth.Permission', verbose_name='user permissions')),
],
options={
'abstract': False,
},
),
# 2. カテゴリモデル
migrations.CreateModel(
name='Category',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('category_name', models.CharField(max_length=255, verbose_name='カテゴリ名')),
('parent_category', models.CharField(blank=True, max_length=255, null=True)),
('created_at', models.DateTimeField(auto_now_add=True)),
('last_updated_at', models.DateTimeField(auto_now=True)),
],
),
# 3. イベント関連モデル
migrations.CreateModel(
name='NewEvent',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('event_code', models.CharField(max_length=255, verbose_name='イベントコード')),
('event_name', models.CharField(max_length=255, verbose_name='イベント名')),
('event_date', models.DateField(verbose_name='イベント日')),
('start_time', models.TimeField(blank=True, null=True, verbose_name='開始時刻')),
('end_time', models.TimeField(blank=True, null=True, verbose_name='終了時刻')),
('description', models.TextField(blank=True, null=True, verbose_name='説明')),
('is_active', models.BooleanField(default=True)),
('created_at', models.DateTimeField(auto_now_add=True)),
('last_updated_at', models.DateTimeField(auto_now=True)),
('category', models.ForeignKey(default=1, on_delete=django.db.models.deletion.DO_NOTHING, to='rog.category')),
],
options={
'db_table': 'rog_newevent',
},
),
# 4. チーム関連モデル
migrations.CreateModel(
name='Team',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('team_name', models.CharField(max_length=255, verbose_name='チーム名')),
('team_member_num', models.IntegerField(blank=True, default=1, null=True, verbose_name='チーム人数')),
('score', models.IntegerField(blank=True, default=0, null=True, verbose_name='スコア')),
('created_at', models.DateTimeField(auto_now_add=True)),
('last_updated_at', models.DateTimeField(auto_now=True)),
('event', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='rog.newevent')),
],
options={
'db_table': 'rog_team',
},
),
# 5. ロケーション関連モデル(基本的なもの)
migrations.CreateModel(
name='Location',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('location_id', models.IntegerField(blank=True, db_index=True, null=True, verbose_name='Location id')),
('sub_loc_id', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Sub location id')),
('cp', models.FloatField(blank=False, default=0, null=True, verbose_name='Check Point')),
('location_name', models.CharField(default='--- 場所をお願いします --', max_length=2048, verbose_name='Location Name')),
('category', models.CharField(blank=True, db_index=True, max_length=2048, null=True, verbose_name='Category')),
('subcategory', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Sub Category')),
('zip', models.CharField(blank=True, max_length=12, null=True, verbose_name='Zip code')),
('address', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Address')),
('prefecture', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Prefecture')),
('area', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Area')),
('city', models.CharField(blank=True, max_length=2048, null=True, verbose_name='City')),
('latitude', models.FloatField(blank=True, null=True, verbose_name='Latitude')),
('longitude', models.FloatField(blank=True, null=True, verbose_name='Latitude')),
('photos', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Photos')),
('videos', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Videos')),
('webcontents', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Web Content')),
('status', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Status')),
('portal', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Portal')),
('group', models.CharField(blank=True, db_index=True, max_length=2048, null=True, verbose_name='Group')),
('phone', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Phone')),
('fax', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Fax')),
('email', models.EmailField(blank=True, max_length=2048, null=True, verbose_name='Email')),
('facility', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Facility')),
('remark', models.CharField(blank=True, max_length=2048, null=True, verbose_name='Remarks')),
('tags', models.CharField(blank=True, max_length=512, null=True, verbose_name='Tags')),
('parammeters', models.CharField(blank=True, max_length=512, null=True, verbose_name='Parameters')),
('created_at', models.DateTimeField(auto_now_add=True)),
('last_updated_at', models.DateTimeField(auto_now=True)),
('last_updated_user', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='location_updated_user', to=settings.AUTH_USER_MODEL)),
],
options={
'db_table': 'rog_location',
},
),
# 6. エントリー関連モデル
migrations.CreateModel(
name='Entry',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('start_time', models.DateTimeField(blank=True, null=True, verbose_name='Start time')),
('goal_time', models.DateTimeField(blank=True, null=True, verbose_name='Goal time')),
('check_point', models.IntegerField(blank=True, null=True, verbose_name='Check Point')),
('created_at', models.DateTimeField(auto_now_add=True)),
('last_updated_at', models.DateTimeField(auto_now=True)),
('location', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='rog.location')),
('team', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='rog.team')),
('last_updated_user', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='entry_updated_user', to=settings.AUTH_USER_MODEL)),
],
options={
'db_table': 'rog_entry',
},
),
]

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,45 @@
# Generated by Django 3.2.9 on 2025-08-29 08:56
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('rog', '0002_fix_all_model_defaults'),
]
operations = [
migrations.RemoveIndex(
model_name='gpscheckin',
name='idx_zekken_event',
),
migrations.AddField(
model_name='gpscheckin',
name='checkin_time',
field=models.DateTimeField(blank=True, help_text='チェックイン時刻(実テーブルフィールド)', null=True),
),
migrations.AddField(
model_name='gpscheckin',
name='team_name',
field=models.CharField(blank=True, help_text='チーム名(実テーブルフィールド)', max_length=255, null=True),
),
migrations.AddField(
model_name='gpscheckin',
name='zekken',
field=models.CharField(blank=True, help_text='ゼッケン番号(実テーブルフィールド名に合わせて修正)', max_length=20, null=True),
),
migrations.AlterField(
model_name='gpscheckin',
name='zekken_number',
field=models.TextField(default='', help_text='ゼッケン番号(後方互換性のため残す)'),
),
migrations.AddIndex(
model_name='gpscheckin',
index=models.Index(fields=['zekken', 'event_code', 'path_order'], name='idx_zekken_event'),
),
migrations.AlterModelTable(
name='gpscheckin',
table='rog_gpscheckin',
),
]

View File

@ -0,0 +1,29 @@
# Generated by Django 3.2.9 on 2025-08-29 09:18
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('rog', '0003_add_missing_fields_to_gpscheckin'),
]
operations = [
migrations.RemoveIndex(
model_name='gpscheckin',
name='idx_zekken_event',
),
migrations.RemoveField(
model_name='gpscheckin',
name='path_order',
),
migrations.RemoveField(
model_name='gpscheckin',
name='zekken_number',
),
migrations.AddIndex(
model_name='gpscheckin',
index=models.Index(fields=['zekken', 'event_code', 'serial_number'], name='idx_zekken_event'),
),
]

View File

@ -0,0 +1,49 @@
# Generated by Django 3.2.9 on 2025-08-29 09:23
import django.contrib.gis.db.models.fields
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('rog', '0004_remove_zekken_number_field'),
]
operations = [
migrations.RenameField(
model_name='gpscheckin',
old_name='lattitude',
new_name='lat',
),
migrations.RenameField(
model_name='gpscheckin',
old_name='longitude',
new_name='lng',
),
migrations.AddField(
model_name='gpscheckin',
name='location',
field=django.contrib.gis.db.models.fields.PointField(blank=True, help_text='位置情報(実テーブルフィールド)', null=True, srid=4326),
),
migrations.AddField(
model_name='gpscheckin',
name='mobserver_id',
field=models.IntegerField(blank=True, help_text='MobServerのID実テーブルフィールド', null=True),
),
migrations.AddField(
model_name='gpscheckin',
name='record_time',
field=models.DateTimeField(blank=True, help_text='記録時刻(実テーブルフィールド)', null=True),
),
migrations.AlterField(
model_name='gpscheckin',
name='cp_number',
field=models.CharField(blank=True, help_text='チェックポイント番号', max_length=20, null=True),
),
migrations.AlterField(
model_name='gpscheckin',
name='serial_number',
field=models.CharField(blank=True, help_text='MobServer gps_information.serial_number', max_length=20, null=True),
),
]

View File

@ -0,0 +1,17 @@
# Generated by Django 3.2.9 on 2025-08-29 09:27
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('rog', '0005_fix_field_mappings'),
]
operations = [
migrations.RemoveField(
model_name='gpscheckin',
name='image_address',
),
]

View File

@ -0,0 +1,18 @@
# Generated by Django 3.2.9 on 2025-08-29 09:36
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('rog', '0006_remove_image_address'),
]
operations = [
# Mark this migration as fake to align with current database state
migrations.RunSQL(
"SELECT 1;", # Do nothing SQL
reverse_sql="SELECT 1;",
),
]