Skip to content

Commit

Permalink
fix(migration): handle permalink edge cases correctly (apache#23980)
Browse files Browse the repository at this point in the history
  • Loading branch information
villebro authored May 9, 2023
1 parent d96b72d commit 7a41170
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 3 deletions.
2 changes: 1 addition & 1 deletion superset/explore/permalink/commands/create.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ def run(self) -> str:
value = {
"chartId": self.chart_id,
"datasourceId": datasource_id,
"datasourceType": datasource_type,
"datasourceType": datasource_type.value,
"datasource": self.datasource,
"state": self.state,
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,10 @@

class RestrictedUnpickler(pickle.Unpickler):
def find_class(self, module, name):
raise pickle.UnpicklingError(f"Unpickling of {module}.{name} is forbidden")
if not (module == "superset.utils.core" and name == "DatasourceType"):
raise pickle.UnpicklingError(f"Unpickling of {module}.{name} is forbidden")

return super().find_class(module, name)


class KeyValueEntry(Base):
Expand All @@ -58,14 +61,28 @@ class KeyValueEntry(Base):
def upgrade():
bind = op.get_bind()
session: Session = db.Session(bind=bind)
truncated_count = 0
for entry in paginated_update(
session.query(KeyValueEntry).filter(
KeyValueEntry.resource.in_(RESOURCES_TO_MIGRATE)
)
):
value = RestrictedUnpickler(io.BytesIO(entry.value)).load() or {}
try:
value = RestrictedUnpickler(io.BytesIO(entry.value)).load() or {}
except pickle.UnpicklingError as ex:
if str(ex) == "pickle data was truncated":
# make truncated values that were created prior to #20385 an empty
# dict so that downgrading will work properly.
truncated_count += 1
value = {}
else:
raise

entry.value = bytes(json.dumps(value), encoding="utf-8")

if truncated_count:
print(f"Replaced {truncated_count} corrupted values with an empty value")


def downgrade():
bind = op.get_bind()
Expand Down

0 comments on commit 7a41170

Please sign in to comment.