From edb74e9394c17952870a25fdadaec1ce16754340 Mon Sep 17 00:00:00 2001 From: Nikhil Mohite Date: Mon, 1 Jan 2024 13:18:23 +0530 Subject: [PATCH] Fix an issue where connection string sequences do not persist after updating server details. #7041 --- .../browser/server_groups/servers/__init__.py | 23 +++++++++++++------ 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/web/pgadmin/browser/server_groups/servers/__init__.py b/web/pgadmin/browser/server_groups/servers/__init__.py index 192f1826b36..808af71fc1f 100644 --- a/web/pgadmin/browser/server_groups/servers/__init__.py +++ b/web/pgadmin/browser/server_groups/servers/__init__.py @@ -8,6 +8,7 @@ ########################################################################## import json +from collections import OrderedDict import pgadmin.browser.server_groups as sg from flask import render_template, request, make_response, jsonify, \ current_app, url_for, session @@ -1131,13 +1132,21 @@ def properties(self, gid, sid): def update_connection_string(manager, server): # Get current connection info in dict. con_info = conninfo_to_dict(manager.display_connection_string) - - # Update host, port and user - con_info['host'] = server.host - con_info['port'] = server.port - con_info['user'] = server.username - - display_conn_string = make_conninfo(**con_info) + db_name = con_info['dbname'] if 'dbname' in con_info else None + + if 'host' in con_info and 'port' in con_info and 'user' in con_info: + con_info.pop('host') + con_info.pop('port') + con_info.pop('user') + + # Create ordered dict to maintain the order of updated host, port, + # dbname, user. + con_info_ord = OrderedDict([('host', server.host), + ('port', server.port), + ('dbname', db_name), + ('user', server.username)]) + con_info_ord.update(con_info) + display_conn_string = make_conninfo(**con_info_ord) return display_conn_string @login_required