From e6438cf8c3d2200262815840ac597d3f4a22e944 Mon Sep 17 00:00:00 2001 From: Mike Bayer Date: Mon, 4 Dec 2017 11:56:14 -0500 Subject: Allow url.password to be an object The "password" attribute of the :class:`.url.URL` object can now be any user-defined or user-subclassed string object that responds to the Python ``str()`` builtin. The object passed will be maintained as the datamember :attr:`.url.URL.password_original` and will be consulted when the :attr:`.url.URL.password` attribute is read to produce the string value. Change-Id: I91d101c3b10e135ae7e4de60a5104b51776db84f Fixes: #4089 --- lib/sqlalchemy/engine/url.py | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'lib/sqlalchemy/engine') diff --git a/lib/sqlalchemy/engine/url.py b/lib/sqlalchemy/engine/url.py index 1ca5983fd..18b184878 100644 --- a/lib/sqlalchemy/engine/url.py +++ b/lib/sqlalchemy/engine/url.py @@ -54,7 +54,7 @@ class URL(object): host=None, port=None, database=None, query=None): self.drivername = drivername self.username = username - self.password = password + self.password_original = password self.host = host if port is not None: self.port = int(port) @@ -105,6 +105,17 @@ class URL(object): self.database == other.database and \ self.query == other.query + @property + def password(self): + if self.password_original is None: + return None + else: + return util.text_type(self.password_original) + + @password.setter + def password(self, password): + self.password_original = password + def get_backend_name(self): if '+' not in self.drivername: return self.drivername -- cgit v1.2.1