mirror of
https://github.com/jazzband/django-constance.git
synced 2026-03-16 22:40:24 +00:00
41 lines
1.4 KiB
Python
41 lines
1.4 KiB
Python
from logging import getLogger
|
|
|
|
from django.core.management.color import no_style
|
|
from django.db import migrations
|
|
|
|
logger = getLogger(__name__)
|
|
|
|
|
|
def _migrate_from_old_table(apps, schema_editor) -> None:
|
|
"""
|
|
Copies values from old table.
|
|
On new installations just ignore error that table does not exist.
|
|
"""
|
|
connection = schema_editor.connection
|
|
quoted_string = ", ".join([connection.ops.quote_name(item) for item in ["id", "key", "value"]])
|
|
old_table_name = "constance_config"
|
|
with connection.cursor() as cursor:
|
|
if old_table_name not in connection.introspection.table_names():
|
|
logger.info("Old table does not exist, skipping")
|
|
return
|
|
cursor.execute(
|
|
f"INSERT INTO constance_constance ( {quoted_string} ) SELECT {quoted_string} FROM {old_table_name}", # noqa: S608
|
|
[],
|
|
)
|
|
cursor.execute(f"DROP TABLE {old_table_name}", [])
|
|
|
|
Constance = apps.get_model("constance", "Constance")
|
|
sequence_sql = connection.ops.sequence_reset_sql(no_style(), [Constance])
|
|
with connection.cursor() as cursor:
|
|
for sql in sequence_sql:
|
|
cursor.execute(sql)
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
dependencies = [("constance", "0001_initial")]
|
|
|
|
atomic = False
|
|
|
|
operations = [
|
|
migrations.RunPython(_migrate_from_old_table, reverse_code=lambda x, y: None),
|
|
]
|