Mercurial > hg > ltpda
view m-toolbox/classes/+utils/@mysql/connect.m @ 44:409a22968d5e default
Add unit tests
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Tue, 06 Dec 2011 18:42:11 +0100 |
parents | f0afece42f48 |
children |
line wrap: on
line source
% CONNECT connects to an LTPDA repository and returns the connection object. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % DESCRIPTION: CONNECT connects to an LTPDA repository and returns the % connection object. % % CONNECT stores a persistent set of logins where a login has % the fields: % 'hostname' - the hostname of the MySQL server % 'db' - the name of the database % 'user' - the username for connection to this db % 'passwd' - the password for this user % % If a login for the requested hostname and db doesn't exist, % or if the existing login is too old (*) then the user is % prompted to log in again. % % (*) the expiry time for MySQL logins is set to 30s. % % CALL: conn = connect(hostname) % connects to 'test' database % conn = connect(hostname, dbname) % dialog prompt for username and password % [conn, password] = connect(hostname, dbname) % return password to caller % conn = connect(hostname, dbname, dbuser, dbpass) % connect with explicit username and password % % VERSION: $Id: connect.m,v 1.8 2010/01/22 12:46:08 ingo Exp $ % % HISTORY: 24-05-2007 M Hewitson % Creation % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % (*) the expiry time for MySQL logins is a property of the % LTPDA Toolbox and can be set in the LTPDA Preferences. function varargout = connect(varargin) error('### Obsolete as of LTPDA version 2.2. Replaced my the utils class jmysql (utils.jmysql.%s)', mfilename()); if nargin < 1 error('### Incorrect inputs') end persistent logins; prefs = getappdata(0, 'LTPDApreferences'); expTime = prefs.repository.loginExpiry; dbuser = ''; dbpass = ''; force = false; if nargin == 1 dbhost = varargin{1}; dbname = 'test'; elseif nargin == 2 dbhost = varargin{1}; dbname = varargin{2}; elseif nargin == 3 dbhost = varargin{1}; dbname = varargin{2}; force = varargin{3}; elseif nargin == 4 dbhost = varargin{1}; dbname = varargin{2}; dbuser = varargin{3}; dbpass = varargin{4}; elseif nargin == 5 dbhost = varargin{1}; dbname = varargin{2}; dbuser = varargin{3}; dbpass = varargin{4}; force = varargin{5}; end if isempty(logins) % Prompt for username and password [dbuser, dbpass] = getlogin(dbhost, dbname, dbuser, dbpass, force); % in the case the user clicks cancel if ~ischar(dbuser) && ~ischar(dbpass) if (dbuser == -1 && dbpass == -1) varargout{1} = -1; varargout{2} = -1; return end end % Create a new login login.hostname = dbhost; login.db = dbname; login.user = dbuser; login.passwd = dbpass; login.ts = now; % store this login logins = [logins login]; else % look for a login to this hostname/db loginFound = false; for kk=1:numel(logins) login = logins(kk); dt = (now - login.ts) * 86400; % [s] if strcmp(login.hostname, dbhost) && strcmp(login.db, dbname) if dt < expTime % get the username and password from here dbuser = login.user; dbpass = login.passwd; logins(kk).ts = now; loginFound = true; break; end end end % If we didn't find a login then create a new one if force || isempty(dbuser) || isempty(dbpass) [dbuser, dbpass] = getlogin(dbhost, dbname, dbuser, dbpass, force); % Create a new login login.hostname = dbhost; login.db = dbname; login.user = dbuser; login.passwd = dbpass; login.ts = now; % store this login if ~loginFound logins = [logins login]; end end end %% return if we don't have a dbuser if isempty(dbuser) return end %% Database settings dbdriver = getappdata(0, 'mysql_driver'); dburl = sprintf('jdbc:mysql://%s/%s',dbhost,dbname); disp(sprintf('** Connecting to %s as %s...', dbhost, dbuser)) conn = database(dbname,dbuser,dbpass,dbdriver,dburl); disp('** Connection status:') disp(ping(conn)) % Set outputs if nargout > 0 varargout{1} = conn; if nargout == 2 varargout{2} = dbpass; end end end function [dbuser, dbpass] = getlogin(dbhost, dbname, dbuser, dbpass, force) % first try defaults if isempty(dbuser) dbuser = getappdata(0, 'ltpda_repo_user'); end if isempty(dbpass) dbpass = getappdata(0, 'ltpda_repo_pass'); end % then log-in dialog if force || isempty(dbuser) || isempty(dbpass) ld = logindialog.LoginDialog([], true); ld.setVisible(true) if ~ld.isCancelled dbuser = char(ld.getUsername); dbpass = [char(ld.getPassword)]'; % for some reason we get a column here, so transpose. end if isempty(dbuser) || isempty(dbpass) warning('!!! Login process cancelled.'); dbuser = -1; dbpass = -1; return end end end