diff --git a/superset/views/core.py b/superset/views/core.py index cc349d9f32589..4faede0f3450c 100755 --- a/superset/views/core.py +++ b/superset/views/core.py @@ -843,6 +843,8 @@ def dashboard_permalink( if url_params := state.get("urlParams"): params = parse.urlencode(url_params) url = f"{url}&{params}" + if original_params := request.query_string.decode(): + url = f"{url}&{original_params}" if hash_ := state.get("anchor", state.get("hash")): url = f"{url}#{hash_}" return redirect(url) diff --git a/tests/integration_tests/core_tests.py b/tests/integration_tests/core_tests.py index 0437e3a92a49d..014c37437bfbe 100644 --- a/tests/integration_tests/core_tests.py +++ b/tests/integration_tests/core_tests.py @@ -1208,6 +1208,21 @@ def test_has_table_by_name(self): is True ) + @mock.patch("superset.views.core.request") + @mock.patch( + "superset.commands.dashboard.permalink.get.GetDashboardPermalinkCommand.run" + ) + def test_dashboard_permalink(self, get_dashboard_permalink_mock, request_mock): + request_mock.query_string = b"standalone=3" + get_dashboard_permalink_mock.return_value = {"dashboardId": 1} + self.login() + resp = self.client.get("superset/dashboard/p/123/") + + expected_url = "/superset/dashboard/1?permalink_key=123&standalone=3" + + self.assertEqual(resp.headers["Location"], expected_url) + assert resp.status_code == 302 + if __name__ == "__main__": unittest.main()