mirror of
https://github.com/apache/superset.git
synced 2026-05-12 19:35:17 +00:00
fix: import should accept old keys (#17330)
* fix: import should accept old keys * Fix lint * Preserve V1 schema
This commit is contained in:
committed by
Elizabeth Thompson
parent
c015e661a9
commit
0b8507fe77
@@ -65,10 +65,25 @@ class ExportDatabasesCommand(ExportModelsCommand):
|
||||
include_defaults=True,
|
||||
export_uuids=True,
|
||||
)
|
||||
|
||||
# https://github.com/apache/superset/pull/16756 renamed ``allow_csv_upload``
|
||||
# to ``allow_file_upload`, but we can't change the V1 schema
|
||||
replacements = {"allow_file_upload": "allow_csv_upload"}
|
||||
# this preserves key order, which is important
|
||||
payload = {replacements.get(key, key): value for key, value in payload.items()}
|
||||
|
||||
# TODO (betodealmeida): move this logic to export_to_dict once this
|
||||
# becomes the default export endpoint
|
||||
if payload.get("extra"):
|
||||
payload["extra"] = parse_extra(payload["extra"])
|
||||
extra = payload["extra"] = parse_extra(payload["extra"])
|
||||
|
||||
# ``schemas_allowed_for_csv_upload`` was also renamed to
|
||||
# ``schemas_allowed_for_file_upload``, we need to change to preserve the
|
||||
# V1 schema
|
||||
if "schemas_allowed_for_file_upload" in extra:
|
||||
extra["schemas_allowed_for_csv_upload"] = extra.pop(
|
||||
"schemas_allowed_for_file_upload"
|
||||
)
|
||||
|
||||
payload["version"] = EXPORT_VERSION
|
||||
|
||||
|
||||
@@ -32,6 +32,13 @@ def import_database(
|
||||
return existing
|
||||
config["id"] = existing.id
|
||||
|
||||
# https://github.com/apache/superset/pull/16756 renamed ``csv`` to ``file``.
|
||||
config["allow_file_upload"] = config.pop("allow_csv_upload")
|
||||
if "schemas_allowed_for_csv_upload" in config["extra"]:
|
||||
config["extra"]["schemas_allowed_for_file_upload"] = config["extra"].pop(
|
||||
"schemas_allowed_for_csv_upload"
|
||||
)
|
||||
|
||||
# TODO (betodealmeida): move this logic to import_from_dict
|
||||
config["extra"] = json.dumps(config["extra"])
|
||||
|
||||
|
||||
@@ -558,11 +558,19 @@ class ImportV1DatabaseExtraSchema(Schema):
|
||||
self, data: Dict[str, Any], **kwargs: Any
|
||||
) -> Dict[str, Any]:
|
||||
"""
|
||||
Fix ``schemas_allowed_for_csv_upload`` being a string.
|
||||
|
||||
Due to a bug in the database modal, some databases might have been
|
||||
saved and exported with a string for ``schemas_allowed_for_csv_upload``.
|
||||
Fixes for ``schemas_allowed_for_csv_upload``.
|
||||
"""
|
||||
# Fix for https://github.com/apache/superset/pull/16756, which temporarily
|
||||
# changed the V1 schema. We need to support exports made after that PR and
|
||||
# before this PR.
|
||||
if "schemas_allowed_for_file_upload" in data:
|
||||
data["schemas_allowed_for_csv_upload"] = data.pop(
|
||||
"schemas_allowed_for_file_upload"
|
||||
)
|
||||
|
||||
# Fix ``schemas_allowed_for_csv_upload`` being a string.
|
||||
# Due to a bug in the database modal, some databases might have been
|
||||
# saved and exported with a string for ``schemas_allowed_for_csv_upload``.
|
||||
schemas_allowed_for_csv_upload = data.get("schemas_allowed_for_csv_upload")
|
||||
if isinstance(schemas_allowed_for_csv_upload, str):
|
||||
data["schemas_allowed_for_csv_upload"] = json.loads(
|
||||
@@ -579,6 +587,22 @@ class ImportV1DatabaseExtraSchema(Schema):
|
||||
|
||||
|
||||
class ImportV1DatabaseSchema(Schema):
|
||||
# pylint: disable=no-self-use, unused-argument
|
||||
@pre_load
|
||||
def fix_allow_csv_upload(
|
||||
self, data: Dict[str, Any], **kwargs: Any
|
||||
) -> Dict[str, Any]:
|
||||
"""
|
||||
Fix for ``allow_csv_upload`` .
|
||||
"""
|
||||
# Fix for https://github.com/apache/superset/pull/16756, which temporarily
|
||||
# changed the V1 schema. We need to support exports made after that PR and
|
||||
# before this PR.
|
||||
if "allow_file_upload" in data:
|
||||
data["allow_csv_upload"] = data.pop("allow_file_upload")
|
||||
|
||||
return data
|
||||
|
||||
database_name = fields.String(required=True)
|
||||
sqlalchemy_uri = fields.String(required=True)
|
||||
password = fields.String(allow_none=True)
|
||||
|
||||
Reference in New Issue
Block a user